From e057d3c16c5ffb36464f63345f7ec0c111abada2 Mon Sep 17 00:00:00 2001 From: Eric Arellano <14852634+Eric-Arellano@users.noreply.github.com> Date: Fri, 17 May 2024 05:05:00 -0400 Subject: [PATCH] Prepare Qiskit 1.1 docs (#1400) We will set up redirects in closed source. The new circuit module rewrite suffers from https://github.com/Qiskit/documentation/issues/1401. That's not blocking this release, though. --- docs/api/qiskit/0.19/_toc.json | 4 + docs/api/qiskit/0.24/_toc.json | 4 + docs/api/qiskit/0.25/_toc.json | 4 + docs/api/qiskit/0.26/_toc.json | 4 + docs/api/qiskit/0.27/_toc.json | 4 + docs/api/qiskit/0.28/_toc.json | 4 + docs/api/qiskit/0.29/_toc.json | 4 + docs/api/qiskit/0.30/_toc.json | 4 + docs/api/qiskit/0.31/_toc.json | 4 + docs/api/qiskit/0.32/_toc.json | 4 + docs/api/qiskit/0.33/_toc.json | 4 + docs/api/qiskit/0.35/_toc.json | 4 + docs/api/qiskit/0.36/_toc.json | 4 + docs/api/qiskit/0.37/_toc.json | 4 + docs/api/qiskit/0.38/_toc.json | 4 + docs/api/qiskit/0.39/_toc.json | 4 + docs/api/qiskit/0.40/_toc.json | 4 + docs/api/qiskit/0.41/_toc.json | 4 + docs/api/qiskit/0.42/_toc.json | 4 + docs/api/qiskit/0.43/_toc.json | 4 + docs/api/qiskit/0.44/_toc.json | 4 + docs/api/qiskit/0.45/_toc.json | 4 + docs/api/qiskit/0.46/_toc.json | 4 + docs/api/qiskit/1.0/_package.json | 4 + docs/api/qiskit/1.0/_toc.json | 2392 ++++++++++ docs/api/qiskit/1.0/assembler.mdx | 180 + docs/api/qiskit/1.0/circuit.mdx | 353 ++ docs/api/qiskit/1.0/circuit_classical.mdx | 938 ++++ docs/api/qiskit/1.0/circuit_library.mdx | 1150 +++++ docs/api/qiskit/1.0/circuit_singleton.mdx | 208 + docs/api/qiskit/1.0/classicalfunction.mdx | 84 + docs/api/qiskit/1.0/compiler.mdx | 304 ++ docs/api/qiskit/1.0/converters.mdx | 248 + docs/api/qiskit/1.0/dagcircuit.mdx | 50 + docs/api/qiskit/1.0/exceptions.mdx | 107 + docs/api/qiskit/1.0/index.mdx | 47 + docs/api/qiskit/1.0/passmanager.mdx | 170 + docs/api/qiskit/1.0/primitives.mdx | 351 ++ docs/api/qiskit/1.0/providers.mdx | 499 ++ .../qiskit/1.0/providers_basic_provider.mdx | 52 + .../qiskit/1.0/providers_fake_provider.mdx | 122 + docs/api/qiskit/1.0/providers_models.mdx | 39 + docs/api/qiskit/1.0/pulse.mdx | 2062 ++++++++ docs/api/qiskit/1.0/qasm2.mdx | 512 ++ docs/api/qiskit/1.0/qasm3.mdx | 405 ++ .../qiskit/1.0/qiskit.assembler.RunConfig.mdx | 100 + .../{ => 1.0}/qiskit.circuit.AncillaQubit.mdx | 0 .../qiskit.circuit.AncillaRegister.mdx | 0 .../1.0/qiskit.circuit.AnnotatedOperation.mdx | 117 + .../qiskit/{ => 1.0}/qiskit.circuit.Bit.mdx | 0 .../qiskit/1.0/qiskit.circuit.BreakLoopOp.mdx | 307 ++ .../1.0/qiskit.circuit.CircuitInstruction.mdx | 78 + .../qiskit.circuit.ClassicalRegister.mdx | 0 .../qiskit/{ => 1.0}/qiskit.circuit.Clbit.mdx | 0 .../qiskit.circuit.CommutationChecker.mdx | 0 .../1.0/qiskit.circuit.ContinueLoopOp.mdx | 311 ++ .../1.0/qiskit.circuit.ControlFlowOp.mdx | 313 ++ .../qiskit.circuit.ControlModifier.mdx | 0 .../1.0/qiskit.circuit.ControlledGate.mdx | 448 ++ .../qiskit/{ => 1.0}/qiskit.circuit.Delay.mdx | 0 .../1.0/qiskit.circuit.EquivalenceLibrary.mdx | 168 + .../qiskit/1.0/qiskit.circuit.ForLoopOp.mdx | 326 ++ docs/api/qiskit/1.0/qiskit.circuit.Gate.mdx | 382 ++ .../qiskit/1.0/qiskit.circuit.IfElseOp.mdx | 338 ++ .../qiskit/1.0/qiskit.circuit.Instruction.mdx | 293 ++ .../1.0/qiskit.circuit.InstructionSet.mdx | 113 + .../qiskit.circuit.InverseModifier.mdx | 0 .../qiskit/1.0/qiskit.circuit.Operation.mdx | 53 + .../qiskit/1.0/qiskit.circuit.Parameter.mdx | 252 + .../qiskit.circuit.ParameterExpression.mdx | 236 + .../1.0/qiskit.circuit.ParameterVector.mdx | 46 + .../qiskit.circuit.PowerModifier.mdx | 0 .../1.0/qiskit.circuit.QuantumCircuit.mdx | 3189 +++++++++++++ .../qiskit.circuit.QuantumRegister.mdx | 0 .../qiskit/{ => 1.0}/qiskit.circuit.Qubit.mdx | 0 .../{ => 1.0}/qiskit.circuit.Register.mdx | 0 .../1.0/qiskit.circuit.SwitchCaseOp.mdx | 348 ++ .../qiskit/1.0/qiskit.circuit.WhileLoopOp.mdx | 327 ++ ...it.classicalfunction.BooleanExpression.mdx | 436 ++ ...it.classicalfunction.ClassicalFunction.mdx | 491 ++ ...ion.ClassicalFunctionCompilerTypeError.mdx | 18 + ...alfunction.ClassicalFunctionParseError.mdx | 18 + .../qiskit/1.0/qiskit.circuit.library.AND.mdx | 206 + .../qiskit.circuit.library.Barrier.mdx | 0 .../1.0/qiskit.circuit.library.C3SXGate.mdx | 162 + .../1.0/qiskit.circuit.library.C3XGate.mdx | 194 + .../1.0/qiskit.circuit.library.C4XGate.mdx | 198 + .../1.0/qiskit.circuit.library.CCXGate.mdx | 250 + .../1.0/qiskit.circuit.library.CCZGate.mdx | 204 + ...t.circuit.library.CDKMRippleCarryAdder.mdx | 262 ++ .../1.0/qiskit.circuit.library.CHGate.mdx | 207 + .../1.0/qiskit.circuit.library.CPhaseGate.mdx | 215 + .../1.0/qiskit.circuit.library.CRXGate.mdx | 221 + .../1.0/qiskit.circuit.library.CRYGate.mdx | 223 + .../1.0/qiskit.circuit.library.CRZGate.mdx | 223 + .../1.0/qiskit.circuit.library.CSGate.mdx | 201 + .../1.0/qiskit.circuit.library.CSXGate.mdx | 197 + .../1.0/qiskit.circuit.library.CSdgGate.mdx | 201 + .../1.0/qiskit.circuit.library.CSwapGate.mdx | 238 + .../1.0/qiskit.circuit.library.CU1Gate.mdx | 219 + .../1.0/qiskit.circuit.library.CU3Gate.mdx | 225 + .../1.0/qiskit.circuit.library.CUGate.mdx | 215 + .../1.0/qiskit.circuit.library.CXGate.mdx | 246 + .../1.0/qiskit.circuit.library.CYGate.mdx | 217 + .../1.0/qiskit.circuit.library.CZGate.mdx | 198 + .../1.0/qiskit.circuit.library.DCXGate.mdx | 139 + .../1.0/qiskit.circuit.library.Diagonal.mdx | 234 + .../qiskit.circuit.library.DiagonalGate.mdx | 131 + .../qiskit.circuit.library.DraperQFTAdder.mdx | 233 + .../1.0/qiskit.circuit.library.ECRGate.mdx | 183 + .../qiskit.circuit.library.EfficientSU2.mdx | 331 ++ ....circuit.library.EvolvedOperatorAnsatz.mdx | 305 ++ ...qiskit.circuit.library.ExactReciprocal.mdx | 203 + ...t.circuit.library.ExcitationPreserving.mdx | 350 ++ ...qiskit.circuit.library.FourierChecking.mdx | 217 + ...rcuit.library.FunctionalPauliRotations.mdx | 168 + .../qiskit/1.0/qiskit.circuit.library.GMS.mdx | 226 + .../qiskit/1.0/qiskit.circuit.library.GR.mdx | 220 + .../qiskit/1.0/qiskit.circuit.library.GRX.mdx | 219 + .../qiskit/1.0/qiskit.circuit.library.GRY.mdx | 219 + .../qiskit/1.0/qiskit.circuit.library.GRZ.mdx | 219 + ...qiskit.circuit.library.GlobalPhaseGate.mdx | 153 + .../1.0/qiskit.circuit.library.GraphState.mdx | 224 + .../qiskit.circuit.library.GroverOperator.mdx | 359 ++ .../1.0/qiskit.circuit.library.HGate.mdx | 180 + ...ircuit.library.HRSCumulativeMultiplier.mdx | 256 + ...qiskit.circuit.library.HamiltonianGate.mdx | 157 + ...t.circuit.library.HiddenLinearFunction.mdx | 226 + .../1.0/qiskit.circuit.library.IGate.mdx | 164 + .../qiskit/1.0/qiskit.circuit.library.IQP.mdx | 214 + .../1.0/qiskit.circuit.library.Initialize.mdx | 164 + .../qiskit.circuit.library.InnerProduct.mdx | 225 + ...skit.circuit.library.IntegerComparator.mdx | 175 + .../1.0/qiskit.circuit.library.Isometry.mdx | 168 + ...ircuit.library.LinearAmplitudeFunction.mdx | 260 ++ .../qiskit.circuit.library.LinearFunction.mdx | 235 + ...t.circuit.library.LinearPauliRotations.mdx | 215 + .../1.0/qiskit.circuit.library.MCMT.mdx | 238 + .../1.0/qiskit.circuit.library.MCMTVChain.mdx | 256 + .../qiskit.circuit.library.MCPhaseGate.mdx | 201 + .../1.0/qiskit.circuit.library.MCXGate.mdx | 212 + .../qiskit.circuit.library.MCXGrayCode.mdx | 179 + .../qiskit.circuit.library.MCXRecursive.mdx | 185 + .../1.0/qiskit.circuit.library.MCXVChain.mdx | 183 + .../1.0/qiskit.circuit.library.MSGate.mdx | 121 + .../qiskit.circuit.library.Measure.mdx | 0 .../1.0/qiskit.circuit.library.NLocal.mdx | 432 ++ .../qiskit/1.0/qiskit.circuit.library.OR.mdx | 206 + ...kit.circuit.library.PauliEvolutionGate.mdx | 190 + ...qiskit.circuit.library.PauliFeatureMap.mdx | 394 ++ .../1.0/qiskit.circuit.library.PauliGate.mdx | 142 + .../qiskit.circuit.library.PauliTwoDesign.mdx | 309 ++ .../qiskit.circuit.library.Permutation.mdx | 208 + ...qiskit.circuit.library.PermutationGate.mdx | 151 + ...qiskit.circuit.library.PhaseEstimation.mdx | 225 + .../1.0/qiskit.circuit.library.PhaseGate.mdx | 208 + .../qiskit.circuit.library.PhaseOracle.mdx | 258 + ...kit.circuit.library.PiecewiseChebyshev.mdx | 221 + ....library.PiecewiseLinearPauliRotations.mdx | 256 + ...rary.PiecewisePolynomialPauliRotations.mdx | 288 ++ ...rcuit.library.PolynomialPauliRotations.mdx | 218 + .../1.0/qiskit.circuit.library.QAOAAnsatz.mdx | 325 ++ .../qiskit/1.0/qiskit.circuit.library.QFT.mdx | 229 + .../qiskit.circuit.library.QuadraticForm.mdx | 249 + .../qiskit.circuit.library.QuantumVolume.mdx | 213 + .../1.0/qiskit.circuit.library.RC3XGate.mdx | 121 + .../1.0/qiskit.circuit.library.RCCXGate.mdx | 121 + ...qiskit.circuit.library.RGQFTMultiplier.mdx | 235 + .../1.0/qiskit.circuit.library.RGate.mdx | 163 + .../1.0/qiskit.circuit.library.RVGate.mdx | 163 + .../1.0/qiskit.circuit.library.RXGate.mdx | 186 + .../1.0/qiskit.circuit.library.RXXGate.mdx | 189 + .../1.0/qiskit.circuit.library.RYGate.mdx | 186 + .../1.0/qiskit.circuit.library.RYYGate.mdx | 189 + .../1.0/qiskit.circuit.library.RZGate.mdx | 196 + .../1.0/qiskit.circuit.library.RZXGate.mdx | 229 + .../1.0/qiskit.circuit.library.RZZGate.mdx | 201 + .../qiskit.circuit.library.RealAmplitudes.mdx | 369 ++ .../qiskit.circuit.library.Reset.mdx | 0 .../1.0/qiskit.circuit.library.SGate.mdx | 166 + .../1.0/qiskit.circuit.library.SXGate.mdx | 189 + .../1.0/qiskit.circuit.library.SXdgGate.mdx | 156 + .../1.0/qiskit.circuit.library.SdgGate.mdx | 166 + ...iskit.circuit.library.StatePreparation.mdx | 203 + .../1.0/qiskit.circuit.library.SwapGate.mdx | 188 + .../1.0/qiskit.circuit.library.TGate.mdx | 166 + .../1.0/qiskit.circuit.library.TdgGate.mdx | 166 + .../1.0/qiskit.circuit.library.TwoLocal.mdx | 393 ++ .../1.0/qiskit.circuit.library.U1Gate.mdx | 215 + .../1.0/qiskit.circuit.library.U2Gate.mdx | 195 + .../1.0/qiskit.circuit.library.U3Gate.mdx | 211 + .../1.0/qiskit.circuit.library.UCGate.mdx | 163 + .../qiskit.circuit.library.UCPauliRotGate.mdx | 120 + .../1.0/qiskit.circuit.library.UCRXGate.mdx | 119 + .../1.0/qiskit.circuit.library.UCRYGate.mdx | 119 + .../1.0/qiskit.circuit.library.UCRZGate.mdx | 119 + .../1.0/qiskit.circuit.library.UGate.mdx | 194 + .../qiskit.circuit.library.UnitaryGate.mdx | 196 + .../qiskit.circuit.library.UnitaryOverlap.mdx | 235 + ...it.circuit.library.VBERippleCarryAdder.mdx | 234 + .../qiskit.circuit.library.WeightedAdder.mdx | 231 + .../1.0/qiskit.circuit.library.XGate.mdx | 198 + .../qiskit/1.0/qiskit.circuit.library.XOR.mdx | 208 + .../qiskit.circuit.library.XXMinusYYGate.mdx | 199 + .../qiskit.circuit.library.XXPlusYYGate.mdx | 199 + .../1.0/qiskit.circuit.library.YGate.mdx | 198 + .../qiskit.circuit.library.ZFeatureMap.mdx | 347 ++ .../1.0/qiskit.circuit.library.ZGate.mdx | 204 + .../qiskit.circuit.library.ZZFeatureMap.mdx | 352 ++ .../1.0/qiskit.circuit.library.iSwapGate.mdx | 176 + .../1.0/qiskit.dagcircuit.DAGCircuit.mdx | 886 ++++ .../1.0/qiskit.dagcircuit.DAGDepNode.mdx | 111 + .../1.0/qiskit.dagcircuit.DAGDependency.mdx | 344 ++ .../1.0/qiskit.dagcircuit.DAGInNode.mdx | 51 + .../qiskit/1.0/qiskit.dagcircuit.DAGNode.mdx | 41 + .../1.0/qiskit.dagcircuit.DAGOpNode.mdx | 65 + .../1.0/qiskit.dagcircuit.DAGOutNode.mdx | 51 + .../1.0/qiskit.passmanager.BaseController.mdx | 67 + .../qiskit.passmanager.BasePassManager.mdx | 131 + ...skit.passmanager.ConditionalController.mdx | 73 + .../qiskit.passmanager.DoWhileController.mdx | 75 + ...iskit.passmanager.FlowControllerLinear.mdx | 73 + .../1.0/qiskit.passmanager.GenericPass.mdx | 87 + .../qiskit.passmanager.PassManagerState.mdx | 34 + .../1.0/qiskit.passmanager.PropertySet.mdx | 78 + .../1.0/qiskit.passmanager.WorkflowStatus.mdx | 38 + .../qiskit.primitives.BackendEstimator.mdx | 130 + .../1.0/qiskit.primitives.BackendSampler.mdx | 125 + .../1.0/qiskit.primitives.BaseEstimator.mdx | 14 + .../1.0/qiskit.primitives.BaseEstimatorV1.mdx | 137 + .../1.0/qiskit.primitives.BaseEstimatorV2.mdx | 41 + .../qiskit.primitives.BasePrimitiveJob.mdx | 101 + .../1.0/qiskit.primitives.BaseSampler.mdx | 14 + .../1.0/qiskit.primitives.BaseSamplerV1.mdx | 116 + .../1.0/qiskit.primitives.BaseSamplerV2.mdx | 41 + .../qiskit/1.0/qiskit.primitives.BitArray.mdx | 230 + .../qiskit/1.0/qiskit.primitives.DataBin.mdx | 18 + .../1.0/qiskit.primitives.Estimator.mdx | 97 + .../1.0/qiskit.primitives.EstimatorResult.mdx | 37 + .../1.0/qiskit.primitives.PrimitiveJob.mdx | 98 + .../1.0/qiskit.primitives.PrimitiveResult.mdx | 29 + .../1.0/qiskit.primitives.PubResult.mdx | 37 + .../qiskit/1.0/qiskit.primitives.Sampler.mdx | 79 + .../1.0/qiskit.primitives.SamplerResult.mdx | 37 + ...qiskit.primitives.StatevectorEstimator.mdx | 121 + .../qiskit.primitives.StatevectorSampler.mdx | 128 + .../qiskit/1.0/qiskit.providers.Backend.mdx | 24 + .../qiskit/1.0/qiskit.providers.BackendV1.mdx | 193 + .../qiskit/1.0/qiskit.providers.BackendV2.mdx | 362 ++ .../qiskit.providers.BackendV2Converter.mdx | 315 ++ docs/api/qiskit/1.0/qiskit.providers.Job.mdx | 24 + .../qiskit/1.0/qiskit.providers.JobStatus.mdx | 46 + .../api/qiskit/1.0/qiskit.providers.JobV1.mdx | 152 + .../qiskit/1.0/qiskit.providers.Options.mdx | 111 + .../qiskit/1.0/qiskit.providers.Provider.mdx | 24 + .../1.0/qiskit.providers.ProviderV1.mdx | 68 + .../1.0/qiskit.providers.QubitProperties.mdx | 40 + ...providers.basic_provider.BasicProvider.mdx | 68 + ...ders.basic_provider.BasicProviderError.mdx | 18 + ...viders.basic_provider.BasicProviderJob.mdx | 158 + ...roviders.basic_provider.BasicSimulator.mdx | 389 ++ .../qiskit.providers.convert_to_target.mdx | 31 + ...roviders.fake_provider.Fake127QPulseV1.mdx | 159 + .../qiskit.providers.fake_provider.Fake1Q.mdx | 118 + ...skit.providers.fake_provider.Fake20QV1.mdx | 155 + ...providers.fake_provider.Fake27QPulseV1.mdx | 171 + ...iskit.providers.fake_provider.Fake5QV1.mdx | 153 + ....providers.fake_provider.Fake7QPulseV1.mdx | 165 + ...roviders.fake_provider.FakeOpenPulse2Q.mdx | 129 + ...roviders.fake_provider.FakeOpenPulse3Q.mdx | 127 + ...oviders.fake_provider.GenericBackendV2.mdx | 336 ++ ....providers.models.BackendConfiguration.mdx | 132 + ...kit.providers.models.BackendProperties.mdx | 288 ++ .../qiskit.providers.models.BackendStatus.mdx | 64 + .../1.0/qiskit.providers.models.Command.mdx | 65 + .../qiskit.providers.models.GateConfig.mdx | 80 + ...qiskit.providers.models.GateProperties.mdx | 77 + .../1.0/qiskit.providers.models.JobStatus.mdx | 80 + .../1.0/qiskit.providers.models.Nduv.mdx | 83 + ...iders.models.PulseBackendConfiguration.mdx | 264 ++ .../qiskit.providers.models.PulseDefaults.mdx | 58 + ...viders.models.QasmBackendConfiguration.mdx | 198 + .../qiskit.providers.models.UchannelLO.mdx | 73 + .../qiskit.pulse.InstructionScheduleMap.mdx | 219 + docs/api/qiskit/1.0/qiskit.pulse.Schedule.mdx | 464 ++ .../qiskit/1.0/qiskit.pulse.ScheduleBlock.mdx | 523 +++ .../qiskit.pulse.channels.AcquireChannel.mdx | 60 + .../qiskit.pulse.channels.ControlChannel.mdx | 60 + .../qiskit.pulse.channels.DriveChannel.mdx | 60 + .../qiskit.pulse.channels.MeasureChannel.mdx | 60 + .../1.0/qiskit.pulse.channels.MemorySlot.mdx | 60 + .../qiskit.pulse.channels.RegisterSlot.mdx | 60 + .../qiskit.pulse.channels.SnapshotChannel.mdx | 56 + .../1.0/qiskit.pulse.instructions.Acquire.mdx | 238 + .../1.0/qiskit.pulse.instructions.Delay.mdx | 212 + .../1.0/qiskit.pulse.instructions.Play.mdx | 206 + .../qiskit.pulse.instructions.Reference.mdx | 211 + ...kit.pulse.instructions.RelativeBarrier.mdx | 193 + ...qiskit.pulse.instructions.SetFrequency.mdx | 214 + .../qiskit.pulse.instructions.SetPhase.mdx | 212 + ...skit.pulse.instructions.ShiftFrequency.mdx | 204 + .../qiskit.pulse.instructions.ShiftPhase.mdx | 216 + .../qiskit.pulse.instructions.Snapshot.mdx | 210 + ...qiskit.pulse.instructions.TimeBlockade.mdx | 229 + ...iskit.pulse.library.Constant_class.rst.mdx | 41 + .../qiskit.pulse.library.Cos_class.rst.mdx | 42 + .../qiskit.pulse.library.Drag_class.rst.mdx | 57 + .../qiskit.pulse.library.GaussianDeriv.mdx | 42 + .../qiskit.pulse.library.GaussianSquare.mdx | 75 + ...iskit.pulse.library.GaussianSquareDrag.mdx | 88 + ...iskit.pulse.library.Gaussian_class.rst.mdx | 46 + ...iskit.pulse.library.Sawtooth_class.rst.mdx | 43 + .../1.0/qiskit.pulse.library.SechDeriv.mdx | 42 + .../1.0/qiskit.pulse.library.Sech_fun.rst.mdx | 51 + .../qiskit.pulse.library.Sin_class.rst.mdx | 42 + .../qiskit.pulse.library.Square_fun.rst.mdx | 43 + .../qiskit.pulse.library.SymbolicPulse.mdx | 254 + ...iskit.pulse.library.Triangle_class.rst.mdx | 42 + .../1.0/qiskit.pulse.library.Waveform.mdx | 105 + ...kit.pulse.library.gaussian_square_echo.mdx | 75 + ...iskit.pulse.transforms.AlignEquispaced.mdx | 58 + .../1.0/qiskit.pulse.transforms.AlignFunc.mdx | 78 + .../1.0/qiskit.pulse.transforms.AlignLeft.mdx | 48 + .../qiskit.pulse.transforms.AlignRight.mdx | 48 + ...iskit.pulse.transforms.AlignSequential.mdx | 48 + .../1.0/qiskit.qobj.GateCalibration.mdx | 59 + .../1.0/qiskit.qobj.PulseLibraryItem.mdx | 57 + docs/api/qiskit/1.0/qiskit.qobj.PulseQobj.mdx | 78 + .../1.0/qiskit.qobj.PulseQobjConfig.mdx | 67 + .../1.0/qiskit.qobj.PulseQobjExperiment.mdx | 60 + .../qiskit.qobj.PulseQobjExperimentConfig.mdx | 58 + .../1.0/qiskit.qobj.PulseQobjInstruction.mdx | 72 + ...qiskit.qobj.QasmExperimentCalibrations.mdx | 56 + docs/api/qiskit/1.0/qiskit.qobj.QasmQobj.mdx | 78 + .../qiskit/1.0/qiskit.qobj.QasmQobjConfig.mdx | 69 + .../1.0/qiskit.qobj.QasmQobjExperiment.mdx | 60 + .../qiskit.qobj.QasmQobjExperimentConfig.mdx | 57 + .../1.0/qiskit.qobj.QasmQobjInstruction.mdx | 67 + .../1.0/qiskit.qobj.QobjExperimentHeader.mdx | 56 + .../api/qiskit/1.0/qiskit.qobj.QobjHeader.mdx | 56 + .../1.0/qiskit.qobj.QobjMeasurementOption.mdx | 57 + .../1.0/qiskit.quantum_info.CNOTDihedral.mdx | 327 ++ .../qiskit/1.0/qiskit.quantum_info.Chi.mdx | 353 ++ .../qiskit/1.0/qiskit.quantum_info.Choi.mdx | 365 ++ .../1.0/qiskit.quantum_info.Clifford.mdx | 607 +++ .../1.0/qiskit.quantum_info.DensityMatrix.mdx | 645 +++ .../qiskit/1.0/qiskit.quantum_info.Kraus.mdx | 353 ++ .../1.0/qiskit.quantum_info.Operator.mdx | 438 ++ .../qiskit/1.0/qiskit.quantum_info.PTM.mdx | 361 ++ .../qiskit/1.0/qiskit.quantum_info.Pauli.mdx | 541 +++ .../1.0/qiskit.quantum_info.PauliList.mdx | 801 ++++ .../1.0/qiskit.quantum_info.Quaternion.mdx | 112 + .../1.0/qiskit.quantum_info.ScalarOp.mdx | 266 ++ .../1.0/qiskit.quantum_info.SparsePauliOp.mdx | 817 ++++ .../qiskit.quantum_info.StabilizerState.mdx | 427 ++ .../1.0/qiskit.quantum_info.Statevector.mdx | 674 +++ .../1.0/qiskit.quantum_info.Stinespring.mdx | 357 ++ .../1.0/qiskit.quantum_info.SuperOp.mdx | 353 ++ .../1.0/qiskit.quantum_info.Z2Symmetries.mdx | 180 + .../1.0/qiskit.quantum_info.pauli_basis.mdx | 29 + .../qiskit.result.BaseReadoutMitigator.mdx | 63 + ...skit.result.CorrelatedReadoutMitigator.mdx | 154 + docs/api/qiskit/1.0/qiskit.result.Counts.mdx | 170 + .../qiskit.result.LocalReadoutMitigator.mdx | 160 + .../1.0/qiskit.result.ProbDistribution.mdx | 133 + .../1.0/qiskit.result.QuasiDistribution.mdx | 169 + docs/api/qiskit/1.0/qiskit.result.Result.mdx | 242 + .../qiskit/1.0/qiskit.result.ResultError.mdx | 32 + .../qiskit.synthesis.EvolutionSynthesis.mdx | 52 + .../1.0/qiskit.synthesis.LieTrotter.mdx | 75 + .../qiskit.synthesis.MatrixExponential.mdx | 54 + ...skit.synthesis.OneQubitEulerDecomposer.mdx | 122 + .../1.0/qiskit.synthesis.ProductFormula.mdx | 62 + .../qiskit/1.0/qiskit.synthesis.QDrift.mdx | 64 + ...t.synthesis.SolovayKitaevDecomposition.mdx | 85 + .../1.0/qiskit.synthesis.SuzukiTrotter.mdx | 82 + ...skit.synthesis.TwoQubitBasisDecomposer.mdx | 108 + ...it.synthesis.TwoQubitWeylDecomposition.mdx | 134 + .../1.0/qiskit.synthesis.XXDecomposer.mdx | 59 + .../1.0/qiskit.synthesis.unitary.aqc.AQC.mdx | 41 + ...nthesis.unitary.aqc.ApproximateCircuit.mdx | 217 + ...sis.unitary.aqc.ApproximatingObjective.mdx | 68 + ....synthesis.unitary.aqc.CNOTUnitCircuit.mdx | 219 + ...ynthesis.unitary.aqc.CNOTUnitObjective.mdx | 41 + ...s.unitary.aqc.DefaultCNOTUnitObjective.mdx | 79 + ...esis.unitary.aqc.FastCNOTUnitObjective.mdx | 63 + .../1.0/qiskit.synthesis.unitary.aqc.mdx | 168 + .../1.0/qiskit.transpiler.AnalysisPass.mdx | 99 + .../1.0/qiskit.transpiler.CouplingMap.mdx | 382 ++ ...qiskit.transpiler.InstructionDurations.mdx | 106 + ...iskit.transpiler.InstructionProperties.mdx | 50 + .../qiskit/1.0/qiskit.transpiler.Layout.mdx | 237 + .../1.0/qiskit.transpiler.PassManager.mdx | 156 + .../qiskit.transpiler.PassManagerConfig.mdx | 66 + .../qiskit.transpiler.StagedPassManager.mdx | 176 + .../qiskit/1.0/qiskit.transpiler.Target.mdx | 591 +++ .../qiskit.transpiler.TransformationPass.mdx | 99 + .../1.0/qiskit.transpiler.TranspileLayout.mdx | 214 + .../qiskit.transpiler.passes.ALAPSchedule.mdx | 118 + ...transpiler.passes.ALAPScheduleAnalysis.mdx | 121 + .../qiskit.transpiler.passes.ASAPSchedule.mdx | 122 + ...transpiler.passes.ASAPScheduleAnalysis.mdx | 121 + ...qiskit.transpiler.passes.AlignMeasures.mdx | 155 + .../qiskit.transpiler.passes.ApplyLayout.mdx | 111 + ....passes.BarrierBeforeFinalMeasurements.mdx | 93 + .../qiskit.transpiler.passes.BasicSwap.mdx | 117 + ...skit.transpiler.passes.BasisTranslator.mdx | 162 + .../qiskit.transpiler.passes.CSPLayout.mdx | 108 + ...iskit.transpiler.passes.CXCancellation.mdx | 103 + ...t.transpiler.passes.CheckGateDirection.mdx | 104 + .../1.0/qiskit.transpiler.passes.CheckMap.mdx | 106 + ...qiskit.transpiler.passes.Collect1qRuns.mdx | 95 + ...skit.transpiler.passes.Collect2qBlocks.mdx | 95 + ...kit.transpiler.passes.CollectCliffords.mdx | 109 + ...anspiler.passes.CollectLinearFunctions.mdx | 109 + ....transpiler.passes.CollectMultiQBlocks.mdx | 119 + ....transpiler.passes.CommutationAnalysis.mdx | 95 + ...nspiler.passes.CommutativeCancellation.mdx | 120 + ....passes.CommutativeInverseCancellation.mdx | 108 + ...ranspiler.passes.Commuting2qGateRouter.mdx | 194 + ...it.transpiler.passes.ConsolidateBlocks.mdx | 111 + ...ranspiler.passes.ConstrainedReschedule.mdx | 165 + ....transpiler.passes.ContainsInstruction.mdx | 100 + ...spiler.passes.ConvertConditionsToIfOps.mdx | 101 + .../1.0/qiskit.transpiler.passes.CountOps.mdx | 93 + ....transpiler.passes.CountOpsLongestPath.mdx | 93 + ...qiskit.transpiler.passes.DAGFixedPoint.mdx | 93 + ...iskit.transpiler.passes.DAGLongestPath.mdx | 91 + .../qiskit.transpiler.passes.Decompose.mdx | 109 + .../qiskit.transpiler.passes.DenseLayout.mdx | 115 + .../1.0/qiskit.transpiler.passes.Depth.mdx | 95 + ....transpiler.passes.DynamicalDecoupling.mdx | 192 + ...spiler.passes.EchoRZXWeylDecomposition.mdx | 118 + ...t.transpiler.passes.EnlargeWithAncilla.mdx | 109 + ...qiskit.transpiler.passes.FilterOpNodes.mdx | 122 + .../qiskit.transpiler.passes.FixedPoint.mdx | 99 + ...ranspiler.passes.FullAncillaAllocation.mdx | 129 + ...qiskit.transpiler.passes.GateDirection.mdx | 143 + .../qiskit.transpiler.passes.GatesInBasis.mdx | 98 + .../qiskit.transpiler.passes.HLSConfig.mdx | 63 + ...t.transpiler.passes.HighLevelSynthesis.mdx | 142 + ...iskit.transpiler.passes.HoareOptimizer.mdx | 109 + ...spiler.passes.InstructionDurationCheck.mdx | 108 + ....transpiler.passes.InverseCancellation.mdx | 113 + ...kit.transpiler.passes.Layout2qDistance.mdx | 100 + ...r.passes.LinearFunctionsToPermutations.mdx | 99 + ...qiskit.transpiler.passes.LookaheadSwap.mdx | 135 + ...ranspiler.passes.MergeAdjacentBarriers.mdx | 128 + .../qiskit.transpiler.passes.MinimumPoint.mdx | 111 + ...kit.transpiler.passes.NormalizeRXAngle.mdx | 144 + ...kit.transpiler.passes.NumTensorFactors.mdx | 93 + ...skit.transpiler.passes.Optimize1qGates.mdx | 144 + ...er.passes.Optimize1qGatesDecomposition.mdx | 119 + ...asses.Optimize1qGatesSimpleCommutation.mdx | 113 + ...it.transpiler.passes.OptimizeAnnotated.mdx | 118 + ...it.transpiler.passes.OptimizeCliffords.mdx | 103 + .../1.0/qiskit.transpiler.passes.PadDelay.mdx | 139 + ...anspiler.passes.PadDynamicalDecoupling.mdx | 197 + .../qiskit.transpiler.passes.PulseGates.mdx | 164 + ...transpiler.passes.RXCalibrationBuilder.mdx | 173 + ...ranspiler.passes.RZXCalibrationBuilder.mdx | 183 + ...ler.passes.RZXCalibrationBuilderNoEcho.mdx | 185 + ...iskit.transpiler.passes.RemoveBarriers.mdx | 114 + ...asses.RemoveDiagonalGatesBeforeMeasure.mdx | 105 + ...nspiler.passes.RemoveFinalMeasurements.mdx | 107 + ...anspiler.passes.RemoveResetInZeroState.mdx | 103 + ...passes.ResetAfterMeasureSimplification.mdx | 93 + .../qiskit.transpiler.passes.SabreLayout.mdx | 203 + ...iskit.transpiler.passes.SabrePreLayout.mdx | 161 + .../qiskit.transpiler.passes.SabreSwap.mdx | 168 + .../qiskit.transpiler.passes.SetIOLatency.mdx | 106 + .../qiskit.transpiler.passes.SetLayout.mdx | 116 + .../1.0/qiskit.transpiler.passes.Size.mdx | 97 + ...qiskit.transpiler.passes.SolovayKitaev.mdx | 196 + ...iskit.transpiler.passes.StochasticSwap.mdx | 129 + ...transpiler.passes.TemplateOptimization.mdx | 112 + ...t.transpiler.passes.TimeUnitConversion.mdx | 122 + ...ler.passes.TranslateParameterizedGates.mdx | 164 + ...qiskit.transpiler.passes.TrivialLayout.mdx | 115 + ...kit.transpiler.passes.UnitarySynthesis.mdx | 125 + ...iskit.transpiler.passes.Unroll3qOrMore.mdx | 114 + ...nspiler.passes.UnrollCustomDefinitions.mdx | 126 + ...iskit.transpiler.passes.UnrollForLoops.mdx | 113 + .../qiskit.transpiler.passes.VF2Layout.mdx | 127 + ...qiskit.transpiler.passes.VF2PostLayout.mdx | 130 + ...t.transpiler.passes.ValidatePulseGates.mdx | 122 + .../1.0/qiskit.transpiler.passes.Width.mdx | 93 + ...ynthesis.aqc_plugin.AQCSynthesisPlugin.mdx | 177 + ...evel_synthesis.ACGSynthesisPermutation.mdx | 26 + ...gh_level_synthesis.AGSynthesisClifford.mdx | 26 + ...gh_level_synthesis.BMSynthesisClifford.mdx | 28 + ...el_synthesis.BasicSynthesisPermutation.mdx | 26 + ...vel_synthesis.DefaultSynthesisClifford.mdx | 28 + ...nthesis.DefaultSynthesisLinearFunction.mdx | 26 + ...evel_synthesis.GreedySynthesisClifford.mdx | 26 + ...l_synthesis.KMSSynthesisLinearFunction.mdx | 26 + ...evel_synthesis.KMSSynthesisPermutation.mdx | 26 + ...el_synthesis.LayerLnnSynthesisClifford.mdx | 26 + ...level_synthesis.LayerSynthesisClifford.mdx | 26 + ...l_synthesis.PMHSynthesisLinearFunction.mdx | 26 + ...hesis.TokenSwapperSynthesisPermutation.mdx | 40 + ...thesis.plugin.HighLevelSynthesisPlugin.mdx | 44 + ...plugin.HighLevelSynthesisPluginManager.mdx | 30 + ...ynthesis.plugin.UnitarySynthesisPlugin.mdx | 196 + ...s.plugin.UnitarySynthesisPluginManager.mdx | 18 + ...ugin.high_level_synthesis_plugin_names.mdx | 28 + ....plugin.unitary_synthesis_plugin_names.mdx | 24 + ...itaev_synthesis.SolovayKitaevSynthesis.mdx | 169 + ...tary_synthesis.DefaultUnitarySynthesis.mdx | 87 + ...managers.plugin.PassManagerStagePlugin.mdx | 35 + ...s.plugin.PassManagerStagePluginManager.mdx | 28 + .../qiskit.visualization.array_to_latex.mdx | 49 + .../qiskit.visualization.circuit_drawer.mdx | 121 + .../1.0/qiskit.visualization.dag_drawer.mdx | 60 + ...skit.visualization.pass_manager_drawer.mdx | 60 + ...t.visualization.plot_bloch_multivector.mdx | 83 + ...qiskit.visualization.plot_bloch_vector.mdx | 60 + ...skit.visualization.plot_circuit_layout.mdx | 56 + ...qiskit.visualization.plot_coupling_map.mdx | 60 + ...qiskit.visualization.plot_distribution.mdx | 77 + .../qiskit.visualization.plot_error_map.mdx | 48 + .../qiskit.visualization.plot_gate_map.mdx | 59 + .../qiskit.visualization.plot_histogram.mdx | 78 + .../qiskit.visualization.plot_state_city.mdx | 87 + ...qiskit.visualization.plot_state_hinton.mdx | 60 + ...skit.visualization.plot_state_paulivec.mdx | 90 + ...iskit.visualization.plot_state_qsphere.mdx | 79 + .../qiskit.visualization.timeline_drawer.mdx | 319 ++ ...kit.visualization.visualize_transition.mdx | 37 + docs/api/qiskit/1.0/qobj.mdx | 51 + docs/api/qiskit/1.0/qpy.mdx | 1145 +++++ docs/api/qiskit/1.0/quantum_info.mdx | 890 ++++ docs/api/qiskit/1.0/result.mdx | 152 + docs/api/qiskit/1.0/scheduler.mdx | 116 + docs/api/qiskit/1.0/synthesis.mdx | 783 ++++ docs/api/qiskit/1.0/transpiler.mdx | 985 ++++ docs/api/qiskit/1.0/transpiler_passes.mdx | 179 + docs/api/qiskit/1.0/transpiler_plugins.mdx | 164 + docs/api/qiskit/1.0/transpiler_preset.mdx | 372 ++ .../1.0/transpiler_synthesis_plugins.mdx | 297 ++ docs/api/qiskit/1.0/utils.mdx | 500 ++ docs/api/qiskit/1.0/visualization.mdx | 233 + docs/api/qiskit/_package.json | 2 +- docs/api/qiskit/_toc.json | 96 +- docs/api/qiskit/assembler.mdx | 14 +- docs/api/qiskit/circuit.mdx | 1072 ++++- docs/api/qiskit/circuit_classical.mdx | 314 +- docs/api/qiskit/circuit_library.mdx | 154 +- docs/api/qiskit/circuit_singleton.mdx | 12 +- docs/api/qiskit/classicalfunction.mdx | 18 + docs/api/qiskit/compiler.mdx | 24 +- docs/api/qiskit/converters.mdx | 164 +- docs/api/qiskit/dagcircuit.mdx | 4 +- docs/api/qiskit/dev/_package.json | 2 +- docs/api/qiskit/dev/_toc.json | 8 + docs/api/qiskit/dev/assembler.mdx | 6 +- docs/api/qiskit/dev/circuit.mdx | 155 +- docs/api/qiskit/dev/circuit_classical.mdx | 112 +- docs/api/qiskit/dev/circuit_library.mdx | 142 +- docs/api/qiskit/dev/circuit_singleton.mdx | 8 +- docs/api/qiskit/dev/classicalfunction.mdx | 2 +- docs/api/qiskit/dev/compiler.mdx | 8 +- docs/api/qiskit/dev/converters.mdx | 16 +- docs/api/qiskit/dev/dagcircuit.mdx | 12 +- docs/api/qiskit/dev/exceptions.mdx | 14 +- docs/api/qiskit/dev/index.mdx | 1 + docs/api/qiskit/dev/passmanager.mdx | 2 +- docs/api/qiskit/dev/primitives.mdx | 1 + docs/api/qiskit/dev/providers.mdx | 38 +- .../qiskit/dev/providers_fake_provider.mdx | 6 +- docs/api/qiskit/dev/pulse.mdx | 86 +- docs/api/qiskit/dev/qasm2.mdx | 16 +- docs/api/qiskit/dev/qasm3.mdx | 24 +- .../qiskit/dev/qiskit.assembler.RunConfig.mdx | 6 +- .../dev/qiskit.circuit.AnnotatedOperation.mdx | 12 +- .../qiskit/dev/qiskit.circuit.BreakLoopOp.mdx | 26 +- .../dev/qiskit.circuit.ContinueLoopOp.mdx | 26 +- .../dev/qiskit.circuit.ControlFlowOp.mdx | 30 +- .../dev/qiskit.circuit.ControlledGate.mdx | 32 +- .../dev/qiskit.circuit.EquivalenceLibrary.mdx | 16 +- .../qiskit/dev/qiskit.circuit.ForLoopOp.mdx | 30 +- docs/api/qiskit/dev/qiskit.circuit.Gate.mdx | 32 +- .../qiskit/dev/qiskit.circuit.IfElseOp.mdx | 30 +- .../qiskit/dev/qiskit.circuit.Instruction.mdx | 26 +- .../dev/qiskit.circuit.InstructionSet.mdx | 8 +- .../qiskit/dev/qiskit.circuit.Operation.mdx | 2 +- .../qiskit/dev/qiskit.circuit.Parameter.mdx | 38 +- .../qiskit.circuit.ParameterExpression.mdx | 38 +- .../dev/qiskit.circuit.ParameterVector.mdx | 6 +- .../dev/qiskit.circuit.QuantumCircuit.mdx | 3826 ++++++++------- .../dev/qiskit.circuit.SwitchCaseOp.mdx | 34 +- .../qiskit/dev/qiskit.circuit.WhileLoopOp.mdx | 30 +- ...it.classicalfunction.BooleanExpression.mdx | 38 +- ...it.classicalfunction.ClassicalFunction.mdx | 40 +- ...ion.ClassicalFunctionCompilerTypeError.mdx | 2 +- ...alfunction.ClassicalFunctionParseError.mdx | 2 +- .../qiskit/dev/qiskit.circuit.library.AND.mdx | 48 +- .../dev/qiskit.circuit.library.C3SXGate.mdx | 2 +- .../dev/qiskit.circuit.library.C3XGate.mdx | 6 +- .../dev/qiskit.circuit.library.C4XGate.mdx | 6 +- .../dev/qiskit.circuit.library.CCXGate.mdx | 6 +- .../dev/qiskit.circuit.library.CCZGate.mdx | 4 +- ...t.circuit.library.CDKMRippleCarryAdder.mdx | 48 +- .../dev/qiskit.circuit.library.CHGate.mdx | 4 +- .../dev/qiskit.circuit.library.CPhaseGate.mdx | 8 +- .../dev/qiskit.circuit.library.CRXGate.mdx | 4 +- .../dev/qiskit.circuit.library.CRYGate.mdx | 4 +- .../dev/qiskit.circuit.library.CRZGate.mdx | 4 +- .../dev/qiskit.circuit.library.CSGate.mdx | 6 +- .../dev/qiskit.circuit.library.CSXGate.mdx | 2 +- .../dev/qiskit.circuit.library.CSdgGate.mdx | 6 +- .../dev/qiskit.circuit.library.CSwapGate.mdx | 4 +- .../dev/qiskit.circuit.library.CU1Gate.mdx | 6 +- .../dev/qiskit.circuit.library.CU3Gate.mdx | 4 +- .../dev/qiskit.circuit.library.CUGate.mdx | 4 +- .../dev/qiskit.circuit.library.CXGate.mdx | 6 +- .../dev/qiskit.circuit.library.CYGate.mdx | 4 +- .../dev/qiskit.circuit.library.CZGate.mdx | 4 +- .../dev/qiskit.circuit.library.DCXGate.mdx | 2 +- .../dev/qiskit.circuit.library.Diagonal.mdx | 46 +- .../qiskit.circuit.library.DiagonalGate.mdx | 6 +- .../qiskit.circuit.library.DraperQFTAdder.mdx | 46 +- .../dev/qiskit.circuit.library.ECRGate.mdx | 4 +- .../qiskit.circuit.library.EfficientSU2.mdx | 40 +- ....circuit.library.EvolvedOperatorAnsatz.mdx | 40 +- ...qiskit.circuit.library.ExactReciprocal.mdx | 46 +- ...t.circuit.library.ExcitationPreserving.mdx | 40 +- ...qiskit.circuit.library.FourierChecking.mdx | 46 +- ...rcuit.library.FunctionalPauliRotations.mdx | 40 +- .../qiskit/dev/qiskit.circuit.library.GMS.mdx | 46 +- .../qiskit/dev/qiskit.circuit.library.GR.mdx | 46 +- .../qiskit/dev/qiskit.circuit.library.GRX.mdx | 46 +- .../qiskit/dev/qiskit.circuit.library.GRY.mdx | 46 +- .../qiskit/dev/qiskit.circuit.library.GRZ.mdx | 46 +- ...qiskit.circuit.library.GlobalPhaseGate.mdx | 4 +- .../dev/qiskit.circuit.library.GraphState.mdx | 46 +- .../qiskit.circuit.library.GroverOperator.mdx | 46 +- .../dev/qiskit.circuit.library.HGate.mdx | 6 +- ...ircuit.library.HRSCumulativeMultiplier.mdx | 46 +- ...qiskit.circuit.library.HamiltonianGate.mdx | 12 +- ...t.circuit.library.HiddenLinearFunction.mdx | 46 +- .../dev/qiskit.circuit.library.IGate.mdx | 6 +- .../qiskit/dev/qiskit.circuit.library.IQP.mdx | 46 +- .../dev/qiskit.circuit.library.Initialize.mdx | 12 +- .../qiskit.circuit.library.InnerProduct.mdx | 46 +- ...skit.circuit.library.IntegerComparator.mdx | 40 +- .../dev/qiskit.circuit.library.Isometry.mdx | 14 +- ...ircuit.library.LinearAmplitudeFunction.mdx | 48 +- .../qiskit.circuit.library.LinearFunction.mdx | 16 +- ...t.circuit.library.LinearPauliRotations.mdx | 40 +- .../dev/qiskit.circuit.library.MCMT.mdx | 50 +- .../dev/qiskit.circuit.library.MCMTVChain.mdx | 48 +- .../qiskit.circuit.library.MCPhaseGate.mdx | 6 +- .../dev/qiskit.circuit.library.MCXGate.mdx | 8 +- .../qiskit.circuit.library.MCXGrayCode.mdx | 4 +- .../qiskit.circuit.library.MCXRecursive.mdx | 6 +- .../dev/qiskit.circuit.library.MCXVChain.mdx | 6 +- .../dev/qiskit.circuit.library.MSGate.mdx | 2 +- .../dev/qiskit.circuit.library.NLocal.mdx | 50 +- .../qiskit/dev/qiskit.circuit.library.OR.mdx | 46 +- ...kit.circuit.library.PauliEvolutionGate.mdx | 4 +- ...qiskit.circuit.library.PauliFeatureMap.mdx | 44 +- .../dev/qiskit.circuit.library.PauliGate.mdx | 6 +- .../qiskit.circuit.library.PauliTwoDesign.mdx | 40 +- .../qiskit.circuit.library.Permutation.mdx | 46 +- ...qiskit.circuit.library.PermutationGate.mdx | 6 +- ...qiskit.circuit.library.PhaseEstimation.mdx | 46 +- .../dev/qiskit.circuit.library.PhaseGate.mdx | 8 +- .../qiskit.circuit.library.PhaseOracle.mdx | 50 +- ...kit.circuit.library.PiecewiseChebyshev.mdx | 40 +- ....library.PiecewiseLinearPauliRotations.mdx | 42 +- ...rary.PiecewisePolynomialPauliRotations.mdx | 42 +- ...rcuit.library.PolynomialPauliRotations.mdx | 40 +- .../dev/qiskit.circuit.library.QAOAAnsatz.mdx | 40 +- .../qiskit/dev/qiskit.circuit.library.QFT.mdx | 44 +- .../qiskit.circuit.library.QuadraticForm.mdx | 48 +- .../qiskit.circuit.library.QuantumVolume.mdx | 48 +- .../dev/qiskit.circuit.library.RC3XGate.mdx | 2 +- .../dev/qiskit.circuit.library.RCCXGate.mdx | 2 +- ...qiskit.circuit.library.RGQFTMultiplier.mdx | 46 +- .../dev/qiskit.circuit.library.RGate.mdx | 6 +- .../dev/qiskit.circuit.library.RVGate.mdx | 6 +- .../dev/qiskit.circuit.library.RXGate.mdx | 8 +- .../dev/qiskit.circuit.library.RXXGate.mdx | 6 +- .../dev/qiskit.circuit.library.RYGate.mdx | 8 +- .../dev/qiskit.circuit.library.RYYGate.mdx | 6 +- .../dev/qiskit.circuit.library.RZGate.mdx | 8 +- .../dev/qiskit.circuit.library.RZXGate.mdx | 6 +- .../dev/qiskit.circuit.library.RZZGate.mdx | 6 +- .../qiskit.circuit.library.RealAmplitudes.mdx | 40 +- .../dev/qiskit.circuit.library.SGate.mdx | 6 +- .../dev/qiskit.circuit.library.SXGate.mdx | 6 +- .../dev/qiskit.circuit.library.SXdgGate.mdx | 4 +- .../dev/qiskit.circuit.library.SdgGate.mdx | 6 +- ...iskit.circuit.library.StatePreparation.mdx | 14 +- .../dev/qiskit.circuit.library.SwapGate.mdx | 6 +- .../dev/qiskit.circuit.library.TGate.mdx | 6 +- .../dev/qiskit.circuit.library.TdgGate.mdx | 6 +- .../dev/qiskit.circuit.library.TwoLocal.mdx | 42 +- .../dev/qiskit.circuit.library.U1Gate.mdx | 6 +- .../dev/qiskit.circuit.library.U2Gate.mdx | 4 +- .../dev/qiskit.circuit.library.U3Gate.mdx | 6 +- .../dev/qiskit.circuit.library.UCGate.mdx | 6 +- .../qiskit.circuit.library.UCPauliRotGate.mdx | 2 +- .../dev/qiskit.circuit.library.UCRXGate.mdx | 2 +- .../dev/qiskit.circuit.library.UCRYGate.mdx | 2 +- .../dev/qiskit.circuit.library.UCRZGate.mdx | 2 +- .../dev/qiskit.circuit.library.UGate.mdx | 6 +- .../qiskit.circuit.library.UnitaryGate.mdx | 14 +- .../qiskit.circuit.library.UnitaryOverlap.mdx | 46 +- ...it.circuit.library.VBERippleCarryAdder.mdx | 46 +- .../qiskit.circuit.library.WeightedAdder.mdx | 40 +- .../dev/qiskit.circuit.library.XGate.mdx | 6 +- .../qiskit/dev/qiskit.circuit.library.XOR.mdx | 46 +- .../qiskit.circuit.library.XXMinusYYGate.mdx | 6 +- .../qiskit.circuit.library.XXPlusYYGate.mdx | 14 +- .../dev/qiskit.circuit.library.YGate.mdx | 6 +- .../qiskit.circuit.library.ZFeatureMap.mdx | 40 +- .../dev/qiskit.circuit.library.ZGate.mdx | 8 +- .../qiskit.circuit.library.ZZFeatureMap.mdx | 40 +- .../dev/qiskit.circuit.library.iSwapGate.mdx | 4 +- .../dev/qiskit.dagcircuit.DAGCircuit.mdx | 162 +- .../dev/qiskit.dagcircuit.DAGDepNode.mdx | 6 +- .../dev/qiskit.dagcircuit.DAGDependency.mdx | 46 +- .../dev/qiskit.dagcircuit.DAGInNode.mdx | 16 +- .../qiskit/dev/qiskit.dagcircuit.DAGNode.mdx | 6 +- .../dev/qiskit.dagcircuit.DAGOpNode.mdx | 28 +- .../dev/qiskit.dagcircuit.DAGOutNode.mdx | 16 +- .../dev/qiskit.passmanager.BaseController.mdx | 6 +- .../qiskit.passmanager.BasePassManager.mdx | 12 +- ...skit.passmanager.ConditionalController.mdx | 6 +- .../qiskit.passmanager.DoWhileController.mdx | 6 +- ...iskit.passmanager.FlowControllerLinear.mdx | 6 +- .../dev/qiskit.passmanager.GenericPass.mdx | 10 +- .../qiskit.passmanager.PassManagerState.mdx | 2 +- .../dev/qiskit.passmanager.PropertySet.mdx | 2 +- .../dev/qiskit.passmanager.WorkflowStatus.mdx | 2 +- .../qiskit.primitives.BackendEstimator.mdx | 8 +- .../qiskit.primitives.BackendEstimatorV2.mdx | 4 +- .../dev/qiskit.primitives.BackendSampler.mdx | 8 +- .../qiskit.primitives.BackendSamplerV2.mdx | 6 +- .../dev/qiskit.primitives.BaseEstimator.mdx | 2 +- .../dev/qiskit.primitives.BaseEstimatorV1.mdx | 6 +- .../dev/qiskit.primitives.BaseEstimatorV2.mdx | 4 +- .../qiskit.primitives.BasePrimitiveJob.mdx | 18 +- .../dev/qiskit.primitives.BaseSampler.mdx | 2 +- .../dev/qiskit.primitives.BaseSamplerV1.mdx | 6 +- .../dev/qiskit.primitives.BaseSamplerV2.mdx | 6 +- .../qiskit/dev/qiskit.primitives.BitArray.mdx | 32 +- .../qiskit/dev/qiskit.primitives.DataBin.mdx | 8 +- .../dev/qiskit.primitives.Estimator.mdx | 6 +- .../dev/qiskit.primitives.EstimatorResult.mdx | 2 +- .../dev/qiskit.primitives.PrimitiveJob.mdx | 18 +- .../dev/qiskit.primitives.PrimitiveResult.mdx | 2 +- .../dev/qiskit.primitives.PubResult.mdx | 2 +- .../qiskit/dev/qiskit.primitives.Sampler.mdx | 6 +- .../qiskit.primitives.SamplerPubResult.mdx | 65 + .../dev/qiskit.primitives.SamplerResult.mdx | 2 +- ...qiskit.primitives.StatevectorEstimator.mdx | 4 +- .../qiskit.primitives.StatevectorSampler.mdx | 6 +- .../qiskit/dev/qiskit.providers.Backend.mdx | 2 +- .../qiskit/dev/qiskit.providers.BackendV1.mdx | 20 +- .../qiskit/dev/qiskit.providers.BackendV2.mdx | 18 +- .../qiskit.providers.BackendV2Converter.mdx | 16 +- docs/api/qiskit/dev/qiskit.providers.Job.mdx | 2 +- .../qiskit/dev/qiskit.providers.JobStatus.mdx | 2 +- .../api/qiskit/dev/qiskit.providers.JobV1.mdx | 24 +- .../qiskit/dev/qiskit.providers.Options.mdx | 6 +- .../qiskit/dev/qiskit.providers.Provider.mdx | 2 +- .../dev/qiskit.providers.ProviderV1.mdx | 6 +- .../dev/qiskit.providers.QubitProperties.mdx | 2 +- ...providers.basic_provider.BasicProvider.mdx | 6 +- ...ders.basic_provider.BasicProviderError.mdx | 2 +- ...viders.basic_provider.BasicProviderJob.mdx | 24 +- ...roviders.basic_provider.BasicSimulator.mdx | 20 +- .../qiskit.providers.convert_to_target.mdx | 2 +- ...roviders.fake_provider.Fake127QPulseV1.mdx | 18 +- .../qiskit.providers.fake_provider.Fake1Q.mdx | 16 +- ...skit.providers.fake_provider.Fake20QV1.mdx | 16 +- ...providers.fake_provider.Fake27QPulseV1.mdx | 18 +- ...iskit.providers.fake_provider.Fake5QV1.mdx | 16 +- ....providers.fake_provider.Fake7QPulseV1.mdx | 18 +- ...roviders.fake_provider.FakeOpenPulse2Q.mdx | 18 +- ...roviders.fake_provider.FakeOpenPulse3Q.mdx | 18 +- ...oviders.fake_provider.GenericBackendV2.mdx | 16 +- ....providers.models.BackendConfiguration.mdx | 6 +- ...kit.providers.models.BackendProperties.mdx | 32 +- .../qiskit.providers.models.BackendStatus.mdx | 6 +- .../dev/qiskit.providers.models.Command.mdx | 6 +- .../qiskit.providers.models.GateConfig.mdx | 6 +- ...qiskit.providers.models.GateProperties.mdx | 6 +- .../dev/qiskit.providers.models.JobStatus.mdx | 6 +- .../dev/qiskit.providers.models.Nduv.mdx | 6 +- ...iders.models.PulseBackendConfiguration.mdx | 20 +- .../qiskit.providers.models.PulseDefaults.mdx | 6 +- ...viders.models.QasmBackendConfiguration.mdx | 6 +- .../qiskit.providers.models.UchannelLO.mdx | 6 +- .../qiskit.pulse.InstructionScheduleMap.mdx | 22 +- docs/api/qiskit/dev/qiskit.pulse.Schedule.mdx | 30 +- .../qiskit/dev/qiskit.pulse.ScheduleBlock.mdx | 28 +- .../qiskit.pulse.channels.AcquireChannel.mdx | 4 +- .../qiskit.pulse.channels.ControlChannel.mdx | 4 +- .../qiskit.pulse.channels.DriveChannel.mdx | 4 +- .../qiskit.pulse.channels.MeasureChannel.mdx | 4 +- .../dev/qiskit.pulse.channels.MemorySlot.mdx | 4 +- .../qiskit.pulse.channels.RegisterSlot.mdx | 4 +- .../qiskit.pulse.channels.SnapshotChannel.mdx | 4 +- .../dev/qiskit.pulse.instructions.Acquire.mdx | 16 +- .../dev/qiskit.pulse.instructions.Delay.mdx | 16 +- .../dev/qiskit.pulse.instructions.Play.mdx | 16 +- .../qiskit.pulse.instructions.Reference.mdx | 16 +- ...kit.pulse.instructions.RelativeBarrier.mdx | 16 +- ...qiskit.pulse.instructions.SetFrequency.mdx | 16 +- .../qiskit.pulse.instructions.SetPhase.mdx | 16 +- ...skit.pulse.instructions.ShiftFrequency.mdx | 16 +- .../qiskit.pulse.instructions.ShiftPhase.mdx | 16 +- .../qiskit.pulse.instructions.Snapshot.mdx | 16 +- ...qiskit.pulse.instructions.TimeBlockade.mdx | 16 +- ...iskit.pulse.library.Constant_class.rst.mdx | 2 +- .../qiskit.pulse.library.Cos_class.rst.mdx | 2 +- .../qiskit.pulse.library.Drag_class.rst.mdx | 2 +- .../qiskit.pulse.library.GaussianDeriv.mdx | 2 +- .../qiskit.pulse.library.GaussianSquare.mdx | 2 +- ...iskit.pulse.library.GaussianSquareDrag.mdx | 2 +- ...iskit.pulse.library.Gaussian_class.rst.mdx | 2 +- ...iskit.pulse.library.Sawtooth_class.rst.mdx | 2 +- .../dev/qiskit.pulse.library.SechDeriv.mdx | 2 +- .../dev/qiskit.pulse.library.Sech_fun.rst.mdx | 2 +- .../qiskit.pulse.library.Sin_class.rst.mdx | 2 +- .../qiskit.pulse.library.Square_fun.rst.mdx | 2 +- .../qiskit.pulse.library.SymbolicPulse.mdx | 10 +- ...iskit.pulse.library.Triangle_class.rst.mdx | 2 +- .../dev/qiskit.pulse.library.Waveform.mdx | 6 +- ...kit.pulse.library.gaussian_square_echo.mdx | 2 +- ...iskit.pulse.transforms.AlignEquispaced.mdx | 4 +- .../dev/qiskit.pulse.transforms.AlignFunc.mdx | 4 +- .../dev/qiskit.pulse.transforms.AlignLeft.mdx | 4 +- .../qiskit.pulse.transforms.AlignRight.mdx | 4 +- ...iskit.pulse.transforms.AlignSequential.mdx | 4 +- .../dev/qiskit.qobj.GateCalibration.mdx | 6 +- .../dev/qiskit.qobj.PulseLibraryItem.mdx | 6 +- docs/api/qiskit/dev/qiskit.qobj.PulseQobj.mdx | 6 +- .../dev/qiskit.qobj.PulseQobjConfig.mdx | 6 +- .../dev/qiskit.qobj.PulseQobjExperiment.mdx | 6 +- .../qiskit.qobj.PulseQobjExperimentConfig.mdx | 6 +- .../dev/qiskit.qobj.PulseQobjInstruction.mdx | 6 +- ...qiskit.qobj.QasmExperimentCalibrations.mdx | 6 +- docs/api/qiskit/dev/qiskit.qobj.QasmQobj.mdx | 6 +- .../qiskit/dev/qiskit.qobj.QasmQobjConfig.mdx | 6 +- .../dev/qiskit.qobj.QasmQobjExperiment.mdx | 6 +- .../qiskit.qobj.QasmQobjExperimentConfig.mdx | 6 +- .../dev/qiskit.qobj.QasmQobjInstruction.mdx | 6 +- .../dev/qiskit.qobj.QobjExperimentHeader.mdx | 6 +- .../api/qiskit/dev/qiskit.qobj.QobjHeader.mdx | 6 +- .../dev/qiskit.qobj.QobjMeasurementOption.mdx | 6 +- .../dev/qiskit.quantum_info.CNOTDihedral.mdx | 34 +- .../qiskit/dev/qiskit.quantum_info.Chi.mdx | 38 +- .../qiskit/dev/qiskit.quantum_info.Choi.mdx | 38 +- .../dev/qiskit.quantum_info.Clifford.mdx | 54 +- .../dev/qiskit.quantum_info.DensityMatrix.mdx | 54 +- .../qiskit/dev/qiskit.quantum_info.Kraus.mdx | 38 +- .../dev/qiskit.quantum_info.Operator.mdx | 46 +- .../qiskit/dev/qiskit.quantum_info.PTM.mdx | 38 +- .../qiskit/dev/qiskit.quantum_info.Pauli.mdx | 50 +- .../dev/qiskit.quantum_info.PauliList.mdx | 66 +- .../dev/qiskit.quantum_info.Quaternion.mdx | 14 +- .../dev/qiskit.quantum_info.ScalarOp.mdx | 32 +- .../dev/qiskit.quantum_info.SparsePauliOp.mdx | 64 +- .../qiskit.quantum_info.StabilizerState.mdx | 68 +- .../dev/qiskit.quantum_info.Statevector.mdx | 54 +- .../dev/qiskit.quantum_info.Stinespring.mdx | 38 +- .../dev/qiskit.quantum_info.SuperOp.mdx | 38 +- .../dev/qiskit.quantum_info.Z2Symmetries.mdx | 12 +- .../dev/qiskit.quantum_info.pauli_basis.mdx | 2 +- .../qiskit.result.BaseReadoutMitigator.mdx | 6 +- ...skit.result.CorrelatedReadoutMitigator.mdx | 12 +- docs/api/qiskit/dev/qiskit.result.Counts.mdx | 10 +- .../qiskit.result.LocalReadoutMitigator.mdx | 12 +- .../dev/qiskit.result.ProbDistribution.mdx | 6 +- .../dev/qiskit.result.QuasiDistribution.mdx | 8 +- docs/api/qiskit/dev/qiskit.result.Result.mdx | 16 +- .../qiskit/dev/qiskit.result.ResultError.mdx | 2 +- .../qiskit.synthesis.EvolutionSynthesis.mdx | 4 +- .../dev/qiskit.synthesis.LieTrotter.mdx | 4 +- .../qiskit.synthesis.MatrixExponential.mdx | 4 +- ...skit.synthesis.OneQubitEulerDecomposer.mdx | 10 +- .../dev/qiskit.synthesis.ProductFormula.mdx | 4 +- .../qiskit/dev/qiskit.synthesis.QDrift.mdx | 4 +- ...t.synthesis.SolovayKitaevDecomposition.mdx | 8 +- .../dev/qiskit.synthesis.SuzukiTrotter.mdx | 4 +- ...skit.synthesis.TwoQubitBasisDecomposer.mdx | 16 +- ...it.synthesis.TwoQubitWeylDecomposition.mdx | 10 +- .../dev/qiskit.synthesis.XXDecomposer.mdx | 6 +- .../dev/qiskit.synthesis.unitary.aqc.AQC.mdx | 4 +- ...nthesis.unitary.aqc.ApproximateCircuit.mdx | 48 +- ...sis.unitary.aqc.ApproximatingObjective.mdx | 6 +- ....synthesis.unitary.aqc.CNOTUnitCircuit.mdx | 48 +- ...ynthesis.unitary.aqc.CNOTUnitObjective.mdx | 2 +- ...s.unitary.aqc.DefaultCNOTUnitObjective.mdx | 6 +- ...esis.unitary.aqc.FastCNOTUnitObjective.mdx | 6 +- .../dev/qiskit.synthesis.unitary.aqc.mdx | 2 +- .../dev/qiskit.transpiler.AnalysisPass.mdx | 10 +- .../dev/qiskit.transpiler.CouplingMap.mdx | 44 +- ...qiskit.transpiler.InstructionDurations.mdx | 10 +- ...iskit.transpiler.InstructionProperties.mdx | 2 +- .../qiskit/dev/qiskit.transpiler.Layout.mdx | 36 +- .../dev/qiskit.transpiler.PassManager.mdx | 14 +- .../qiskit.transpiler.PassManagerConfig.mdx | 4 +- .../qiskit.transpiler.StagedPassManager.mdx | 14 +- .../qiskit/dev/qiskit.transpiler.Target.mdx | 42 +- .../qiskit.transpiler.TransformationPass.mdx | 10 +- .../dev/qiskit.transpiler.TranspileLayout.mdx | 12 +- .../qiskit.transpiler.passes.ALAPSchedule.mdx | 10 +- ...transpiler.passes.ALAPScheduleAnalysis.mdx | 10 +- .../qiskit.transpiler.passes.ASAPSchedule.mdx | 10 +- ...transpiler.passes.ASAPScheduleAnalysis.mdx | 10 +- ...qiskit.transpiler.passes.AlignMeasures.mdx | 10 +- .../qiskit.transpiler.passes.ApplyLayout.mdx | 10 +- ....passes.BarrierBeforeFinalMeasurements.mdx | 10 +- .../qiskit.transpiler.passes.BasicSwap.mdx | 10 +- ...skit.transpiler.passes.BasisTranslator.mdx | 12 +- .../qiskit.transpiler.passes.CSPLayout.mdx | 10 +- ...iskit.transpiler.passes.CXCancellation.mdx | 10 +- ...t.transpiler.passes.CheckGateDirection.mdx | 10 +- .../dev/qiskit.transpiler.passes.CheckMap.mdx | 10 +- ...qiskit.transpiler.passes.Collect1qRuns.mdx | 10 +- ...skit.transpiler.passes.Collect2qBlocks.mdx | 10 +- ...kit.transpiler.passes.CollectCliffords.mdx | 10 +- ...anspiler.passes.CollectLinearFunctions.mdx | 10 +- ....transpiler.passes.CollectMultiQBlocks.mdx | 14 +- ....transpiler.passes.CommutationAnalysis.mdx | 10 +- ...nspiler.passes.CommutativeCancellation.mdx | 10 +- ....passes.CommutativeInverseCancellation.mdx | 10 +- ...ranspiler.passes.Commuting2qGateRouter.mdx | 14 +- ...it.transpiler.passes.ConsolidateBlocks.mdx | 10 +- ...ranspiler.passes.ConstrainedReschedule.mdx | 10 +- ....transpiler.passes.ContainsInstruction.mdx | 10 +- ...spiler.passes.ConvertConditionsToIfOps.mdx | 10 +- .../dev/qiskit.transpiler.passes.CountOps.mdx | 10 +- ....transpiler.passes.CountOpsLongestPath.mdx | 10 +- ...qiskit.transpiler.passes.DAGFixedPoint.mdx | 10 +- ...iskit.transpiler.passes.DAGLongestPath.mdx | 10 +- .../qiskit.transpiler.passes.Decompose.mdx | 10 +- .../qiskit.transpiler.passes.DenseLayout.mdx | 10 +- .../dev/qiskit.transpiler.passes.Depth.mdx | 10 +- ....transpiler.passes.DynamicalDecoupling.mdx | 10 +- ...spiler.passes.EchoRZXWeylDecomposition.mdx | 10 +- ...it.transpiler.passes.ElidePermutations.mdx | 10 +- ...t.transpiler.passes.EnlargeWithAncilla.mdx | 10 +- ...qiskit.transpiler.passes.FilterOpNodes.mdx | 10 +- .../qiskit.transpiler.passes.FixedPoint.mdx | 10 +- ...ranspiler.passes.FullAncillaAllocation.mdx | 12 +- ...qiskit.transpiler.passes.GateDirection.mdx | 10 +- .../qiskit.transpiler.passes.GatesInBasis.mdx | 10 +- .../qiskit.transpiler.passes.HLSConfig.mdx | 4 +- ...t.transpiler.passes.HighLevelSynthesis.mdx | 10 +- ...iskit.transpiler.passes.HoareOptimizer.mdx | 10 +- ...spiler.passes.InstructionDurationCheck.mdx | 10 +- ....transpiler.passes.InverseCancellation.mdx | 10 +- ...kit.transpiler.passes.Layout2qDistance.mdx | 10 +- ...r.passes.LinearFunctionsToPermutations.mdx | 10 +- ...qiskit.transpiler.passes.LookaheadSwap.mdx | 10 +- ...ranspiler.passes.MergeAdjacentBarriers.mdx | 10 +- .../qiskit.transpiler.passes.MinimumPoint.mdx | 10 +- ...kit.transpiler.passes.NormalizeRXAngle.mdx | 12 +- ...kit.transpiler.passes.NumTensorFactors.mdx | 10 +- ...skit.transpiler.passes.Optimize1qGates.mdx | 14 +- ...er.passes.Optimize1qGatesDecomposition.mdx | 10 +- ...asses.Optimize1qGatesSimpleCommutation.mdx | 10 +- ...it.transpiler.passes.OptimizeAnnotated.mdx | 10 +- ...it.transpiler.passes.OptimizeCliffords.mdx | 10 +- .../dev/qiskit.transpiler.passes.PadDelay.mdx | 10 +- ...anspiler.passes.PadDynamicalDecoupling.mdx | 10 +- .../qiskit.transpiler.passes.PulseGates.mdx | 14 +- ...transpiler.passes.RXCalibrationBuilder.mdx | 14 +- ...ranspiler.passes.RZXCalibrationBuilder.mdx | 16 +- ...ler.passes.RZXCalibrationBuilderNoEcho.mdx | 16 +- ...iskit.transpiler.passes.RemoveBarriers.mdx | 10 +- ...asses.RemoveDiagonalGatesBeforeMeasure.mdx | 10 +- ...nspiler.passes.RemoveFinalMeasurements.mdx | 10 +- ...kit.transpiler.passes.RemoveFinalReset.mdx | 10 +- ...anspiler.passes.RemoveResetInZeroState.mdx | 10 +- ...passes.ResetAfterMeasureSimplification.mdx | 10 +- .../qiskit.transpiler.passes.SabreLayout.mdx | 10 +- ...iskit.transpiler.passes.SabrePreLayout.mdx | 10 +- .../qiskit.transpiler.passes.SabreSwap.mdx | 10 +- .../qiskit.transpiler.passes.SetIOLatency.mdx | 10 +- .../qiskit.transpiler.passes.SetLayout.mdx | 10 +- .../dev/qiskit.transpiler.passes.Size.mdx | 10 +- ...qiskit.transpiler.passes.SolovayKitaev.mdx | 10 +- ...iskit.transpiler.passes.StarPreRouting.mdx | 18 +- ...iskit.transpiler.passes.StochasticSwap.mdx | 10 +- ...transpiler.passes.TemplateOptimization.mdx | 10 +- ...t.transpiler.passes.TimeUnitConversion.mdx | 10 +- ...ler.passes.TranslateParameterizedGates.mdx | 10 +- ...qiskit.transpiler.passes.TrivialLayout.mdx | 10 +- ...kit.transpiler.passes.UnitarySynthesis.mdx | 10 +- ...iskit.transpiler.passes.Unroll3qOrMore.mdx | 10 +- ...nspiler.passes.UnrollCustomDefinitions.mdx | 10 +- ...iskit.transpiler.passes.UnrollForLoops.mdx | 10 +- .../qiskit.transpiler.passes.VF2Layout.mdx | 10 +- ...qiskit.transpiler.passes.VF2PostLayout.mdx | 10 +- ...t.transpiler.passes.ValidatePulseGates.mdx | 10 +- .../dev/qiskit.transpiler.passes.Width.mdx | 10 +- ...ynthesis.aqc_plugin.AQCSynthesisPlugin.mdx | 4 +- ...evel_synthesis.ACGSynthesisPermutation.mdx | 4 +- ...gh_level_synthesis.AGSynthesisClifford.mdx | 4 +- ...gh_level_synthesis.BMSynthesisClifford.mdx | 4 +- ...el_synthesis.BasicSynthesisPermutation.mdx | 4 +- ...vel_synthesis.DefaultSynthesisClifford.mdx | 4 +- ...nthesis.DefaultSynthesisLinearFunction.mdx | 4 +- ...evel_synthesis.GreedySynthesisClifford.mdx | 4 +- ...l_synthesis.KMSSynthesisLinearFunction.mdx | 4 +- ...evel_synthesis.KMSSynthesisPermutation.mdx | 4 +- ...el_synthesis.LayerLnnSynthesisClifford.mdx | 4 +- ...level_synthesis.LayerSynthesisClifford.mdx | 4 +- ...l_synthesis.PMHSynthesisLinearFunction.mdx | 4 +- ...hesis.TokenSwapperSynthesisPermutation.mdx | 4 +- ...thesis.plugin.HighLevelSynthesisPlugin.mdx | 4 +- ...plugin.HighLevelSynthesisPluginManager.mdx | 6 +- ...ynthesis.plugin.UnitarySynthesisPlugin.mdx | 4 +- ...s.plugin.UnitarySynthesisPluginManager.mdx | 2 +- ...ugin.high_level_synthesis_plugin_names.mdx | 2 +- ....plugin.unitary_synthesis_plugin_names.mdx | 2 +- ...itaev_synthesis.SolovayKitaevSynthesis.mdx | 4 +- ...tary_synthesis.DefaultUnitarySynthesis.mdx | 4 +- ...managers.plugin.PassManagerStagePlugin.mdx | 4 +- ...s.plugin.PassManagerStagePluginManager.mdx | 4 +- .../qiskit.visualization.array_to_latex.mdx | 2 +- .../qiskit.visualization.circuit_drawer.mdx | 2 +- .../dev/qiskit.visualization.dag_drawer.mdx | 2 +- ...skit.visualization.pass_manager_drawer.mdx | 2 +- ...t.visualization.plot_bloch_multivector.mdx | 4 +- ...qiskit.visualization.plot_bloch_vector.mdx | 6 +- ...skit.visualization.plot_circuit_layout.mdx | 2 +- ...qiskit.visualization.plot_coupling_map.mdx | 2 +- ...qiskit.visualization.plot_distribution.mdx | 4 +- .../qiskit.visualization.plot_error_map.mdx | 2 +- .../qiskit.visualization.plot_gate_map.mdx | 2 +- .../qiskit.visualization.plot_histogram.mdx | 4 +- .../qiskit.visualization.plot_state_city.mdx | 8 +- ...qiskit.visualization.plot_state_hinton.mdx | 8 +- ...skit.visualization.plot_state_paulivec.mdx | 6 +- ...iskit.visualization.plot_state_qsphere.mdx | 6 +- .../qiskit.visualization.timeline_drawer.mdx | 2 +- ...kit.visualization.visualize_transition.mdx | 2 +- docs/api/qiskit/dev/qpy.mdx | 10 +- docs/api/qiskit/dev/quantum_info.mdx | 54 +- docs/api/qiskit/dev/result.mdx | 8 +- docs/api/qiskit/dev/scheduler.mdx | 8 +- docs/api/qiskit/dev/synthesis.mdx | 48 +- docs/api/qiskit/dev/transpiler.mdx | 12 +- docs/api/qiskit/dev/transpiler_passes.mdx | 2 +- docs/api/qiskit/dev/transpiler_plugins.mdx | 4 +- docs/api/qiskit/dev/transpiler_preset.mdx | 26 +- docs/api/qiskit/dev/utils.mdx | 46 +- docs/api/qiskit/dev/visualization.mdx | 2 +- docs/api/qiskit/exceptions.mdx | 14 +- docs/api/qiskit/index.mdx | 65 +- docs/api/qiskit/passmanager.mdx | 2 +- docs/api/qiskit/primitives.mdx | 16 +- docs/api/qiskit/providers.mdx | 87 +- docs/api/qiskit/providers_basic_provider.mdx | 31 +- docs/api/qiskit/providers_fake_provider.mdx | 8 +- docs/api/qiskit/providers_models.mdx | 2 +- docs/api/qiskit/pulse.mdx | 86 +- docs/api/qiskit/qasm2.mdx | 18 +- docs/api/qiskit/qasm3.mdx | 24 +- .../api/qiskit/qiskit.assembler.RunConfig.mdx | 6 +- .../qiskit.circuit.AnnotatedOperation.mdx | 41 +- .../api/qiskit/qiskit.circuit.BreakLoopOp.mdx | 67 +- .../qiskit/qiskit.circuit.ContinueLoopOp.mdx | 71 +- .../qiskit/qiskit.circuit.ControlFlowOp.mdx | 75 +- .../qiskit/qiskit.circuit.ControlledGate.mdx | 55 +- .../qiskit.circuit.EquivalenceLibrary.mdx | 16 +- docs/api/qiskit/qiskit.circuit.ForLoopOp.mdx | 100 +- docs/api/qiskit/qiskit.circuit.Gate.mdx | 55 +- docs/api/qiskit/qiskit.circuit.IfElseOp.mdx | 83 +- .../api/qiskit/qiskit.circuit.Instruction.mdx | 34 +- .../qiskit/qiskit.circuit.InstructionSet.mdx | 46 +- docs/api/qiskit/qiskit.circuit.Operation.mdx | 12 +- docs/api/qiskit/qiskit.circuit.Parameter.mdx | 48 +- .../qiskit.circuit.ParameterExpression.mdx | 38 +- .../qiskit/qiskit.circuit.ParameterVector.mdx | 6 +- .../qiskit/qiskit.circuit.QuantumCircuit.mdx | 4136 ++++++++++------- .../qiskit/qiskit.circuit.SwitchCaseOp.mdx | 96 +- .../api/qiskit/qiskit.circuit.WhileLoopOp.mdx | 106 +- ...it.classicalfunction.BooleanExpression.mdx | 61 +- ...it.classicalfunction.ClassicalFunction.mdx | 63 +- ...ion.ClassicalFunctionCompilerTypeError.mdx | 2 +- ...alfunction.ClassicalFunctionParseError.mdx | 2 +- .../api/qiskit/qiskit.circuit.library.AND.mdx | 80 +- .../qiskit.circuit.library.C3SXGate.mdx | 6 +- .../qiskit/qiskit.circuit.library.C3XGate.mdx | 10 +- .../qiskit/qiskit.circuit.library.C4XGate.mdx | 10 +- .../qiskit/qiskit.circuit.library.CCXGate.mdx | 10 +- .../qiskit/qiskit.circuit.library.CCZGate.mdx | 6 +- ...t.circuit.library.CDKMRippleCarryAdder.mdx | 80 +- .../qiskit/qiskit.circuit.library.CHGate.mdx | 6 +- .../qiskit.circuit.library.CPhaseGate.mdx | 27 +- .../qiskit/qiskit.circuit.library.CRXGate.mdx | 6 +- .../qiskit/qiskit.circuit.library.CRYGate.mdx | 6 +- .../qiskit/qiskit.circuit.library.CRZGate.mdx | 6 +- .../qiskit/qiskit.circuit.library.CSGate.mdx | 25 +- .../qiskit/qiskit.circuit.library.CSXGate.mdx | 4 +- .../qiskit.circuit.library.CSdgGate.mdx | 25 +- .../qiskit.circuit.library.CSwapGate.mdx | 6 +- .../qiskit/qiskit.circuit.library.CU1Gate.mdx | 8 +- .../qiskit/qiskit.circuit.library.CU3Gate.mdx | 6 +- .../qiskit/qiskit.circuit.library.CUGate.mdx | 6 +- .../qiskit/qiskit.circuit.library.CXGate.mdx | 10 +- .../qiskit/qiskit.circuit.library.CYGate.mdx | 6 +- .../qiskit/qiskit.circuit.library.CZGate.mdx | 6 +- .../qiskit/qiskit.circuit.library.DCXGate.mdx | 4 +- .../qiskit.circuit.library.Diagonal.mdx | 80 +- .../qiskit.circuit.library.DiagonalGate.mdx | 8 +- .../qiskit.circuit.library.DraperQFTAdder.mdx | 80 +- .../qiskit/qiskit.circuit.library.ECRGate.mdx | 6 +- .../qiskit.circuit.library.EfficientSU2.mdx | 76 +- ....circuit.library.EvolvedOperatorAnsatz.mdx | 74 +- ...qiskit.circuit.library.ExactReciprocal.mdx | 80 +- ...t.circuit.library.ExcitationPreserving.mdx | 74 +- ...qiskit.circuit.library.FourierChecking.mdx | 80 +- ...rcuit.library.FunctionalPauliRotations.mdx | 74 +- .../api/qiskit/qiskit.circuit.library.GMS.mdx | 80 +- docs/api/qiskit/qiskit.circuit.library.GR.mdx | 80 +- .../api/qiskit/qiskit.circuit.library.GRX.mdx | 80 +- .../api/qiskit/qiskit.circuit.library.GRY.mdx | 80 +- .../api/qiskit/qiskit.circuit.library.GRZ.mdx | 80 +- ...qiskit.circuit.library.GlobalPhaseGate.mdx | 6 +- .../qiskit.circuit.library.GraphState.mdx | 80 +- .../qiskit.circuit.library.GroverOperator.mdx | 80 +- .../qiskit/qiskit.circuit.library.HGate.mdx | 8 +- ...ircuit.library.HRSCumulativeMultiplier.mdx | 80 +- ...qiskit.circuit.library.HamiltonianGate.mdx | 14 +- ...t.circuit.library.HiddenLinearFunction.mdx | 80 +- .../qiskit/qiskit.circuit.library.IGate.mdx | 25 +- .../api/qiskit/qiskit.circuit.library.IQP.mdx | 80 +- .../qiskit.circuit.library.Initialize.mdx | 6 +- .../qiskit.circuit.library.InnerProduct.mdx | 80 +- ...skit.circuit.library.IntegerComparator.mdx | 74 +- .../qiskit.circuit.library.Isometry.mdx | 10 +- ...ircuit.library.LinearAmplitudeFunction.mdx | 82 +- .../qiskit.circuit.library.LinearFunction.mdx | 18 +- ...t.circuit.library.LinearPauliRotations.mdx | 74 +- .../qiskit/qiskit.circuit.library.MCMT.mdx | 86 +- .../qiskit.circuit.library.MCMTVChain.mdx | 84 +- .../qiskit.circuit.library.MCPhaseGate.mdx | 10 +- .../qiskit/qiskit.circuit.library.MCXGate.mdx | 12 +- .../qiskit.circuit.library.MCXGrayCode.mdx | 6 +- .../qiskit.circuit.library.MCXRecursive.mdx | 8 +- .../qiskit.circuit.library.MCXVChain.mdx | 8 +- .../qiskit/qiskit.circuit.library.MSGate.mdx | 4 +- .../qiskit/qiskit.circuit.library.NLocal.mdx | 84 +- docs/api/qiskit/qiskit.circuit.library.OR.mdx | 80 +- ...kit.circuit.library.PauliEvolutionGate.mdx | 6 +- ...qiskit.circuit.library.PauliFeatureMap.mdx | 78 +- .../qiskit.circuit.library.PauliGate.mdx | 8 +- .../qiskit.circuit.library.PauliTwoDesign.mdx | 74 +- .../qiskit.circuit.library.Permutation.mdx | 80 +- ...qiskit.circuit.library.PermutationGate.mdx | 8 +- ...qiskit.circuit.library.PhaseEstimation.mdx | 80 +- .../qiskit.circuit.library.PhaseGate.mdx | 27 +- .../qiskit.circuit.library.PhaseOracle.mdx | 84 +- ...kit.circuit.library.PiecewiseChebyshev.mdx | 74 +- ....library.PiecewiseLinearPauliRotations.mdx | 76 +- ...rary.PiecewisePolynomialPauliRotations.mdx | 76 +- ...rcuit.library.PolynomialPauliRotations.mdx | 74 +- .../qiskit.circuit.library.QAOAAnsatz.mdx | 74 +- .../api/qiskit/qiskit.circuit.library.QFT.mdx | 78 +- .../qiskit.circuit.library.QuadraticForm.mdx | 82 +- .../qiskit.circuit.library.QuantumVolume.mdx | 81 +- .../qiskit.circuit.library.RC3XGate.mdx | 4 +- .../qiskit.circuit.library.RCCXGate.mdx | 4 +- ...qiskit.circuit.library.RGQFTMultiplier.mdx | 80 +- .../qiskit/qiskit.circuit.library.RGate.mdx | 25 +- .../qiskit/qiskit.circuit.library.RVGate.mdx | 8 +- .../qiskit/qiskit.circuit.library.RXGate.mdx | 27 +- .../qiskit/qiskit.circuit.library.RXXGate.mdx | 25 +- .../qiskit/qiskit.circuit.library.RYGate.mdx | 27 +- .../qiskit/qiskit.circuit.library.RYYGate.mdx | 25 +- .../qiskit/qiskit.circuit.library.RZGate.mdx | 27 +- .../qiskit/qiskit.circuit.library.RZXGate.mdx | 25 +- .../qiskit/qiskit.circuit.library.RZZGate.mdx | 25 +- .../qiskit.circuit.library.RealAmplitudes.mdx | 74 +- .../qiskit/qiskit.circuit.library.SGate.mdx | 25 +- .../qiskit/qiskit.circuit.library.SXGate.mdx | 8 +- .../qiskit.circuit.library.SXdgGate.mdx | 6 +- .../qiskit/qiskit.circuit.library.SdgGate.mdx | 25 +- ...iskit.circuit.library.StatePreparation.mdx | 10 +- .../qiskit.circuit.library.SwapGate.mdx | 8 +- .../qiskit/qiskit.circuit.library.TGate.mdx | 25 +- .../qiskit/qiskit.circuit.library.TdgGate.mdx | 25 +- .../qiskit.circuit.library.TwoLocal.mdx | 76 +- .../qiskit/qiskit.circuit.library.U1Gate.mdx | 8 +- .../qiskit/qiskit.circuit.library.U2Gate.mdx | 6 +- .../qiskit/qiskit.circuit.library.U3Gate.mdx | 8 +- .../qiskit/qiskit.circuit.library.UCGate.mdx | 8 +- .../qiskit.circuit.library.UCPauliRotGate.mdx | 4 +- .../qiskit.circuit.library.UCRXGate.mdx | 4 +- .../qiskit.circuit.library.UCRYGate.mdx | 4 +- .../qiskit.circuit.library.UCRZGate.mdx | 4 +- .../qiskit/qiskit.circuit.library.UGate.mdx | 8 +- .../qiskit.circuit.library.UnitaryGate.mdx | 17 +- .../qiskit.circuit.library.UnitaryOverlap.mdx | 88 +- ...it.circuit.library.VBERippleCarryAdder.mdx | 80 +- .../qiskit.circuit.library.WeightedAdder.mdx | 74 +- .../qiskit/qiskit.circuit.library.XGate.mdx | 10 +- .../api/qiskit/qiskit.circuit.library.XOR.mdx | 80 +- .../qiskit.circuit.library.XXMinusYYGate.mdx | 25 +- .../qiskit.circuit.library.XXPlusYYGate.mdx | 25 +- .../qiskit/qiskit.circuit.library.YGate.mdx | 10 +- .../qiskit.circuit.library.ZFeatureMap.mdx | 74 +- .../qiskit/qiskit.circuit.library.ZGate.mdx | 29 +- .../qiskit.circuit.library.ZZFeatureMap.mdx | 74 +- .../qiskit.circuit.library.iSwapGate.mdx | 23 +- .../qiskit/qiskit.dagcircuit.DAGCircuit.mdx | 326 +- .../qiskit/qiskit.dagcircuit.DAGDepNode.mdx | 22 +- .../qiskit.dagcircuit.DAGDependency.mdx | 52 +- .../qiskit/qiskit.dagcircuit.DAGInNode.mdx | 4 +- docs/api/qiskit/qiskit.dagcircuit.DAGNode.mdx | 4 +- .../qiskit/qiskit.dagcircuit.DAGOpNode.mdx | 4 +- .../qiskit/qiskit.dagcircuit.DAGOutNode.mdx | 4 +- .../qiskit.passmanager.BaseController.mdx | 6 +- .../qiskit.passmanager.BasePassManager.mdx | 12 +- ...skit.passmanager.ConditionalController.mdx | 6 +- .../qiskit.passmanager.DoWhileController.mdx | 6 +- ...iskit.passmanager.FlowControllerLinear.mdx | 6 +- .../qiskit/qiskit.passmanager.GenericPass.mdx | 10 +- .../qiskit.passmanager.PassManagerState.mdx | 2 +- .../qiskit/qiskit.passmanager.PropertySet.mdx | 2 +- .../qiskit.passmanager.WorkflowStatus.mdx | 2 +- .../qiskit.primitives.BackendEstimator.mdx | 8 +- .../qiskit.primitives.BackendEstimatorV2.mdx | 68 + .../qiskit.primitives.BackendSampler.mdx | 8 +- .../qiskit.primitives.BackendSamplerV2.mdx | 71 + .../qiskit.primitives.BaseEstimator.mdx | 2 +- .../qiskit.primitives.BaseEstimatorV1.mdx | 6 +- .../qiskit.primitives.BaseEstimatorV2.mdx | 4 +- .../qiskit.primitives.BasePrimitiveJob.mdx | 18 +- .../qiskit/qiskit.primitives.BaseSampler.mdx | 2 +- .../qiskit.primitives.BaseSamplerV1.mdx | 6 +- .../qiskit.primitives.BaseSamplerV2.mdx | 6 +- .../api/qiskit/qiskit.primitives.BitArray.mdx | 200 +- docs/api/qiskit/qiskit.primitives.DataBin.mdx | 72 +- .../qiskit/qiskit.primitives.Estimator.mdx | 6 +- .../qiskit.primitives.EstimatorResult.mdx | 2 +- .../qiskit/qiskit.primitives.PrimitiveJob.mdx | 18 +- .../qiskit.primitives.PrimitiveResult.mdx | 2 +- .../qiskit/qiskit.primitives.PubResult.mdx | 2 +- docs/api/qiskit/qiskit.primitives.Sampler.mdx | 6 +- .../qiskit.primitives.SamplerPubResult.mdx | 65 + .../qiskit.primitives.SamplerResult.mdx | 2 +- docs/api/qiskit/qiskit.primitives.Shaped.mdx | 38 + ...qiskit.primitives.StatevectorEstimator.mdx | 4 +- .../qiskit.primitives.StatevectorSampler.mdx | 6 +- docs/api/qiskit/qiskit.providers.Backend.mdx | 2 +- .../api/qiskit/qiskit.providers.BackendV1.mdx | 22 +- .../api/qiskit/qiskit.providers.BackendV2.mdx | 18 +- .../qiskit.providers.BackendV2Converter.mdx | 18 +- docs/api/qiskit/qiskit.providers.Job.mdx | 2 +- .../api/qiskit/qiskit.providers.JobStatus.mdx | 2 +- docs/api/qiskit/qiskit.providers.JobV1.mdx | 24 +- docs/api/qiskit/qiskit.providers.Options.mdx | 6 +- docs/api/qiskit/qiskit.providers.Provider.mdx | 6 +- .../qiskit/qiskit.providers.ProviderV1.mdx | 14 +- .../qiskit.providers.QubitProperties.mdx | 2 +- ...providers.basic_provider.BasicProvider.mdx | 14 +- ...ders.basic_provider.BasicProviderError.mdx | 2 +- ...viders.basic_provider.BasicProviderJob.mdx | 24 +- ...roviders.basic_provider.BasicSimulator.mdx | 22 +- .../qiskit.providers.convert_to_target.mdx | 2 +- ...roviders.fake_provider.Fake127QPulseV1.mdx | 18 +- .../qiskit.providers.fake_provider.Fake1Q.mdx | 16 +- ...skit.providers.fake_provider.Fake20QV1.mdx | 16 +- ...providers.fake_provider.Fake27QPulseV1.mdx | 18 +- ...iskit.providers.fake_provider.Fake5QV1.mdx | 16 +- ....providers.fake_provider.Fake7QPulseV1.mdx | 18 +- ...roviders.fake_provider.FakeOpenPulse2Q.mdx | 18 +- ...roviders.fake_provider.FakeOpenPulse3Q.mdx | 18 +- ...oviders.fake_provider.GenericBackendV2.mdx | 16 +- ....providers.models.BackendConfiguration.mdx | 6 +- ...kit.providers.models.BackendProperties.mdx | 32 +- .../qiskit.providers.models.BackendStatus.mdx | 6 +- .../qiskit.providers.models.Command.mdx | 6 +- .../qiskit.providers.models.GateConfig.mdx | 6 +- ...qiskit.providers.models.GateProperties.mdx | 6 +- .../qiskit.providers.models.JobStatus.mdx | 6 +- .../qiskit/qiskit.providers.models.Nduv.mdx | 6 +- ...iders.models.PulseBackendConfiguration.mdx | 20 +- .../qiskit.providers.models.PulseDefaults.mdx | 6 +- ...viders.models.QasmBackendConfiguration.mdx | 6 +- .../qiskit.providers.models.UchannelLO.mdx | 6 +- .../qiskit.pulse.InstructionScheduleMap.mdx | 22 +- docs/api/qiskit/qiskit.pulse.Schedule.mdx | 44 +- .../api/qiskit/qiskit.pulse.ScheduleBlock.mdx | 42 +- .../qiskit.pulse.channels.AcquireChannel.mdx | 4 +- .../qiskit.pulse.channels.ControlChannel.mdx | 4 +- .../qiskit.pulse.channels.DriveChannel.mdx | 4 +- .../qiskit.pulse.channels.MeasureChannel.mdx | 4 +- .../qiskit.pulse.channels.MemorySlot.mdx | 4 +- .../qiskit.pulse.channels.RegisterSlot.mdx | 4 +- .../qiskit.pulse.channels.SnapshotChannel.mdx | 4 +- .../qiskit.pulse.instructions.Acquire.mdx | 16 +- .../qiskit.pulse.instructions.Delay.mdx | 16 +- .../qiskit/qiskit.pulse.instructions.Play.mdx | 16 +- .../qiskit.pulse.instructions.Reference.mdx | 16 +- ...kit.pulse.instructions.RelativeBarrier.mdx | 16 +- ...qiskit.pulse.instructions.SetFrequency.mdx | 16 +- .../qiskit.pulse.instructions.SetPhase.mdx | 16 +- ...skit.pulse.instructions.ShiftFrequency.mdx | 16 +- .../qiskit.pulse.instructions.ShiftPhase.mdx | 16 +- .../qiskit.pulse.instructions.Snapshot.mdx | 16 +- ...qiskit.pulse.instructions.TimeBlockade.mdx | 16 +- ...iskit.pulse.library.Constant_class.rst.mdx | 2 +- .../qiskit.pulse.library.Cos_class.rst.mdx | 2 +- .../qiskit.pulse.library.Drag_class.rst.mdx | 2 +- .../qiskit.pulse.library.GaussianDeriv.mdx | 2 +- .../qiskit.pulse.library.GaussianSquare.mdx | 2 +- ...iskit.pulse.library.GaussianSquareDrag.mdx | 2 +- ...iskit.pulse.library.Gaussian_class.rst.mdx | 2 +- ...iskit.pulse.library.Sawtooth_class.rst.mdx | 2 +- .../qiskit/qiskit.pulse.library.SechDeriv.mdx | 2 +- .../qiskit.pulse.library.Sech_fun.rst.mdx | 2 +- .../qiskit.pulse.library.Sin_class.rst.mdx | 2 +- .../qiskit.pulse.library.Square_fun.rst.mdx | 2 +- .../qiskit.pulse.library.SymbolicPulse.mdx | 10 +- ...iskit.pulse.library.Triangle_class.rst.mdx | 2 +- .../qiskit/qiskit.pulse.library.Waveform.mdx | 6 +- ...kit.pulse.library.gaussian_square_echo.mdx | 2 +- ...iskit.pulse.transforms.AlignEquispaced.mdx | 4 +- .../qiskit.pulse.transforms.AlignFunc.mdx | 4 +- .../qiskit.pulse.transforms.AlignLeft.mdx | 4 +- .../qiskit.pulse.transforms.AlignRight.mdx | 4 +- ...iskit.pulse.transforms.AlignSequential.mdx | 4 +- .../qiskit/qiskit.qobj.GateCalibration.mdx | 6 +- .../qiskit/qiskit.qobj.PulseLibraryItem.mdx | 6 +- docs/api/qiskit/qiskit.qobj.PulseQobj.mdx | 6 +- .../qiskit/qiskit.qobj.PulseQobjConfig.mdx | 6 +- .../qiskit.qobj.PulseQobjExperiment.mdx | 6 +- .../qiskit.qobj.PulseQobjExperimentConfig.mdx | 6 +- .../qiskit.qobj.PulseQobjInstruction.mdx | 6 +- ...qiskit.qobj.QasmExperimentCalibrations.mdx | 6 +- docs/api/qiskit/qiskit.qobj.QasmQobj.mdx | 6 +- .../api/qiskit/qiskit.qobj.QasmQobjConfig.mdx | 6 +- .../qiskit/qiskit.qobj.QasmQobjExperiment.mdx | 6 +- .../qiskit.qobj.QasmQobjExperimentConfig.mdx | 6 +- .../qiskit.qobj.QasmQobjInstruction.mdx | 6 +- .../qiskit.qobj.QobjExperimentHeader.mdx | 6 +- docs/api/qiskit/qiskit.qobj.QobjHeader.mdx | 6 +- .../qiskit.qobj.QobjMeasurementOption.mdx | 6 +- .../qiskit.quantum_info.CNOTDihedral.mdx | 34 +- docs/api/qiskit/qiskit.quantum_info.Chi.mdx | 38 +- docs/api/qiskit/qiskit.quantum_info.Choi.mdx | 38 +- .../qiskit/qiskit.quantum_info.Clifford.mdx | 64 +- .../qiskit.quantum_info.DensityMatrix.mdx | 54 +- docs/api/qiskit/qiskit.quantum_info.Kraus.mdx | 38 +- .../qiskit/qiskit.quantum_info.Operator.mdx | 48 +- docs/api/qiskit/qiskit.quantum_info.PTM.mdx | 38 +- docs/api/qiskit/qiskit.quantum_info.Pauli.mdx | 71 +- .../qiskit/qiskit.quantum_info.PauliList.mdx | 86 +- .../qiskit/qiskit.quantum_info.Quaternion.mdx | 14 +- .../qiskit/qiskit.quantum_info.ScalarOp.mdx | 32 +- .../qiskit.quantum_info.SparsePauliOp.mdx | 87 +- .../qiskit.quantum_info.StabilizerState.mdx | 42 +- .../qiskit.quantum_info.Statevector.mdx | 54 +- .../qiskit.quantum_info.Stinespring.mdx | 38 +- .../qiskit/qiskit.quantum_info.SuperOp.mdx | 38 +- .../qiskit.quantum_info.Z2Symmetries.mdx | 12 +- .../qiskit.quantum_info.pauli_basis.mdx | 2 +- .../qiskit.result.BaseReadoutMitigator.mdx | 6 +- ...skit.result.CorrelatedReadoutMitigator.mdx | 12 +- docs/api/qiskit/qiskit.result.Counts.mdx | 10 +- .../qiskit.result.LocalReadoutMitigator.mdx | 12 +- .../qiskit/qiskit.result.ProbDistribution.mdx | 6 +- .../qiskit.result.QuasiDistribution.mdx | 8 +- docs/api/qiskit/qiskit.result.Result.mdx | 16 +- docs/api/qiskit/qiskit.result.ResultError.mdx | 2 +- .../qiskit.synthesis.EvolutionSynthesis.mdx | 4 +- .../qiskit/qiskit.synthesis.LieTrotter.mdx | 4 +- .../qiskit.synthesis.MatrixExponential.mdx | 4 +- ...skit.synthesis.OneQubitEulerDecomposer.mdx | 10 +- .../qiskit.synthesis.ProductFormula.mdx | 4 +- docs/api/qiskit/qiskit.synthesis.QDrift.mdx | 4 +- ...t.synthesis.SolovayKitaevDecomposition.mdx | 8 +- .../qiskit/qiskit.synthesis.SuzukiTrotter.mdx | 4 +- ...skit.synthesis.TwoQubitBasisDecomposer.mdx | 17 +- ...it.synthesis.TwoQubitWeylDecomposition.mdx | 29 +- .../qiskit/qiskit.synthesis.XXDecomposer.mdx | 7 +- .../qiskit.synthesis.unitary.aqc.AQC.mdx | 4 +- ...nthesis.unitary.aqc.ApproximateCircuit.mdx | 82 +- ...sis.unitary.aqc.ApproximatingObjective.mdx | 6 +- ....synthesis.unitary.aqc.CNOTUnitCircuit.mdx | 82 +- ...ynthesis.unitary.aqc.CNOTUnitObjective.mdx | 2 +- ...s.unitary.aqc.DefaultCNOTUnitObjective.mdx | 6 +- ...esis.unitary.aqc.FastCNOTUnitObjective.mdx | 6 +- .../qiskit/qiskit.synthesis.unitary.aqc.mdx | 14 +- .../qiskit/qiskit.transpiler.AnalysisPass.mdx | 10 +- .../qiskit/qiskit.transpiler.CouplingMap.mdx | 44 +- ...qiskit.transpiler.InstructionDurations.mdx | 10 +- ...iskit.transpiler.InstructionProperties.mdx | 2 +- docs/api/qiskit/qiskit.transpiler.Layout.mdx | 82 +- .../qiskit/qiskit.transpiler.PassManager.mdx | 14 +- .../qiskit.transpiler.PassManagerConfig.mdx | 4 +- .../qiskit.transpiler.StagedPassManager.mdx | 14 +- docs/api/qiskit/qiskit.transpiler.Target.mdx | 42 +- .../qiskit.transpiler.TransformationPass.mdx | 10 +- .../qiskit.transpiler.TranspileLayout.mdx | 82 +- .../qiskit.transpiler.passes.ALAPSchedule.mdx | 14 +- ...transpiler.passes.ALAPScheduleAnalysis.mdx | 10 +- .../qiskit.transpiler.passes.ASAPSchedule.mdx | 14 +- ...transpiler.passes.ASAPScheduleAnalysis.mdx | 10 +- ...qiskit.transpiler.passes.AlignMeasures.mdx | 14 +- .../qiskit.transpiler.passes.ApplyLayout.mdx | 10 +- ....passes.BarrierBeforeFinalMeasurements.mdx | 10 +- .../qiskit.transpiler.passes.BasicSwap.mdx | 10 +- ...skit.transpiler.passes.BasisTranslator.mdx | 12 +- .../qiskit.transpiler.passes.CSPLayout.mdx | 10 +- ...iskit.transpiler.passes.CXCancellation.mdx | 14 +- ...t.transpiler.passes.CheckGateDirection.mdx | 10 +- .../qiskit.transpiler.passes.CheckMap.mdx | 10 +- ...qiskit.transpiler.passes.Collect1qRuns.mdx | 10 +- ...skit.transpiler.passes.Collect2qBlocks.mdx | 10 +- ...kit.transpiler.passes.CollectCliffords.mdx | 10 +- ...anspiler.passes.CollectLinearFunctions.mdx | 10 +- ....transpiler.passes.CollectMultiQBlocks.mdx | 14 +- ....transpiler.passes.CommutationAnalysis.mdx | 10 +- ...nspiler.passes.CommutativeCancellation.mdx | 10 +- ....passes.CommutativeInverseCancellation.mdx | 10 +- ...ranspiler.passes.Commuting2qGateRouter.mdx | 12 +- ...it.transpiler.passes.ConsolidateBlocks.mdx | 10 +- ...ranspiler.passes.ConstrainedReschedule.mdx | 11 +- ....transpiler.passes.ContainsInstruction.mdx | 10 +- ...spiler.passes.ConvertConditionsToIfOps.mdx | 10 +- .../qiskit.transpiler.passes.CountOps.mdx | 10 +- ....transpiler.passes.CountOpsLongestPath.mdx | 10 +- ...qiskit.transpiler.passes.DAGFixedPoint.mdx | 10 +- ...iskit.transpiler.passes.DAGLongestPath.mdx | 10 +- .../qiskit.transpiler.passes.Decompose.mdx | 10 +- .../qiskit.transpiler.passes.DenseLayout.mdx | 10 +- .../qiskit/qiskit.transpiler.passes.Depth.mdx | 10 +- ....transpiler.passes.DynamicalDecoupling.mdx | 14 +- ...spiler.passes.EchoRZXWeylDecomposition.mdx | 10 +- ...it.transpiler.passes.ElidePermutations.mdx | 119 + ...t.transpiler.passes.EnlargeWithAncilla.mdx | 10 +- ...qiskit.transpiler.passes.FilterOpNodes.mdx | 10 +- .../qiskit.transpiler.passes.FixedPoint.mdx | 10 +- ...ranspiler.passes.FullAncillaAllocation.mdx | 12 +- ...qiskit.transpiler.passes.GateDirection.mdx | 10 +- .../qiskit.transpiler.passes.GatesInBasis.mdx | 10 +- .../qiskit.transpiler.passes.HLSConfig.mdx | 6 +- ...t.transpiler.passes.HighLevelSynthesis.mdx | 10 +- ...iskit.transpiler.passes.HoareOptimizer.mdx | 10 +- ...spiler.passes.InstructionDurationCheck.mdx | 11 +- ....transpiler.passes.InverseCancellation.mdx | 10 +- ...kit.transpiler.passes.Layout2qDistance.mdx | 10 +- ...r.passes.LinearFunctionsToPermutations.mdx | 10 +- ...qiskit.transpiler.passes.LookaheadSwap.mdx | 10 +- ...ranspiler.passes.MergeAdjacentBarriers.mdx | 10 +- .../qiskit.transpiler.passes.MinimumPoint.mdx | 10 +- ...kit.transpiler.passes.NormalizeRXAngle.mdx | 14 +- ...kit.transpiler.passes.NumTensorFactors.mdx | 10 +- ...skit.transpiler.passes.Optimize1qGates.mdx | 14 +- ...er.passes.Optimize1qGatesDecomposition.mdx | 10 +- ...asses.Optimize1qGatesSimpleCommutation.mdx | 10 +- ...it.transpiler.passes.OptimizeAnnotated.mdx | 12 +- ...it.transpiler.passes.OptimizeCliffords.mdx | 10 +- .../qiskit.transpiler.passes.PadDelay.mdx | 10 +- ...anspiler.passes.PadDynamicalDecoupling.mdx | 10 +- .../qiskit.transpiler.passes.PulseGates.mdx | 14 +- ...transpiler.passes.RXCalibrationBuilder.mdx | 14 +- ...ranspiler.passes.RZXCalibrationBuilder.mdx | 16 +- ...ler.passes.RZXCalibrationBuilderNoEcho.mdx | 16 +- ...iskit.transpiler.passes.RemoveBarriers.mdx | 10 +- ...asses.RemoveDiagonalGatesBeforeMeasure.mdx | 10 +- ...nspiler.passes.RemoveFinalMeasurements.mdx | 10 +- ...kit.transpiler.passes.RemoveFinalReset.mdx | 103 + ...anspiler.passes.RemoveResetInZeroState.mdx | 10 +- ...passes.ResetAfterMeasureSimplification.mdx | 10 +- .../qiskit.transpiler.passes.SabreLayout.mdx | 10 +- ...iskit.transpiler.passes.SabrePreLayout.mdx | 10 +- .../qiskit.transpiler.passes.SabreSwap.mdx | 10 +- .../qiskit.transpiler.passes.SetIOLatency.mdx | 10 +- .../qiskit.transpiler.passes.SetLayout.mdx | 10 +- .../qiskit/qiskit.transpiler.passes.Size.mdx | 10 +- ...qiskit.transpiler.passes.SolovayKitaev.mdx | 10 +- ...iskit.transpiler.passes.StarPreRouting.mdx | 164 + ...iskit.transpiler.passes.StochasticSwap.mdx | 10 +- ...transpiler.passes.TemplateOptimization.mdx | 10 +- ...t.transpiler.passes.TimeUnitConversion.mdx | 10 +- ...ler.passes.TranslateParameterizedGates.mdx | 10 +- ...qiskit.transpiler.passes.TrivialLayout.mdx | 10 +- ...kit.transpiler.passes.UnitarySynthesis.mdx | 10 +- ...iskit.transpiler.passes.Unroll3qOrMore.mdx | 10 +- ...nspiler.passes.UnrollCustomDefinitions.mdx | 10 +- ...iskit.transpiler.passes.UnrollForLoops.mdx | 10 +- .../qiskit.transpiler.passes.VF2Layout.mdx | 10 +- ...qiskit.transpiler.passes.VF2PostLayout.mdx | 10 +- ...t.transpiler.passes.ValidatePulseGates.mdx | 11 +- .../qiskit/qiskit.transpiler.passes.Width.mdx | 10 +- ...ynthesis.aqc_plugin.AQCSynthesisPlugin.mdx | 4 +- ...evel_synthesis.ACGSynthesisPermutation.mdx | 4 +- ...gh_level_synthesis.AGSynthesisClifford.mdx | 4 +- ...gh_level_synthesis.BMSynthesisClifford.mdx | 4 +- ...el_synthesis.BasicSynthesisPermutation.mdx | 4 +- ...vel_synthesis.DefaultSynthesisClifford.mdx | 4 +- ...nthesis.DefaultSynthesisLinearFunction.mdx | 4 +- ...evel_synthesis.GreedySynthesisClifford.mdx | 4 +- ...l_synthesis.KMSSynthesisLinearFunction.mdx | 14 +- ...evel_synthesis.KMSSynthesisPermutation.mdx | 4 +- ...el_synthesis.LayerLnnSynthesisClifford.mdx | 4 +- ...level_synthesis.LayerSynthesisClifford.mdx | 4 +- ...l_synthesis.PMHSynthesisLinearFunction.mdx | 20 +- ...hesis.TokenSwapperSynthesisPermutation.mdx | 4 +- ...thesis.plugin.HighLevelSynthesisPlugin.mdx | 4 +- ...plugin.HighLevelSynthesisPluginManager.mdx | 6 +- ...ynthesis.plugin.UnitarySynthesisPlugin.mdx | 4 +- ...s.plugin.UnitarySynthesisPluginManager.mdx | 2 +- ...ugin.high_level_synthesis_plugin_names.mdx | 2 +- ....plugin.unitary_synthesis_plugin_names.mdx | 2 +- ...itaev_synthesis.SolovayKitaevSynthesis.mdx | 4 +- ...tary_synthesis.DefaultUnitarySynthesis.mdx | 4 +- ...managers.plugin.PassManagerStagePlugin.mdx | 4 +- ...s.plugin.PassManagerStagePluginManager.mdx | 4 +- .../qiskit.visualization.array_to_latex.mdx | 2 +- .../qiskit.visualization.circuit_drawer.mdx | 2 +- .../qiskit.visualization.dag_drawer.mdx | 2 +- ...skit.visualization.pass_manager_drawer.mdx | 2 +- ...t.visualization.plot_bloch_multivector.mdx | 4 +- ...qiskit.visualization.plot_bloch_vector.mdx | 6 +- ...skit.visualization.plot_circuit_layout.mdx | 12 +- ...qiskit.visualization.plot_coupling_map.mdx | 2 +- ...qiskit.visualization.plot_distribution.mdx | 4 +- .../qiskit.visualization.plot_error_map.mdx | 2 +- .../qiskit.visualization.plot_gate_map.mdx | 2 +- .../qiskit.visualization.plot_histogram.mdx | 4 +- .../qiskit.visualization.plot_state_city.mdx | 8 +- ...qiskit.visualization.plot_state_hinton.mdx | 8 +- ...skit.visualization.plot_state_paulivec.mdx | 6 +- ...iskit.visualization.plot_state_qsphere.mdx | 6 +- .../qiskit.visualization.timeline_drawer.mdx | 22 +- ...kit.visualization.visualize_transition.mdx | 2 +- docs/api/qiskit/qpy.mdx | 157 +- docs/api/qiskit/quantum_info.mdx | 54 +- docs/api/qiskit/release-notes/1.0.mdx | 330 +- docs/api/qiskit/release-notes/1.1.mdx | 904 ++++ docs/api/qiskit/release-notes/index.mdx | 1 + docs/api/qiskit/result.mdx | 12 +- docs/api/qiskit/scheduler.mdx | 14 +- docs/api/qiskit/synthesis.mdx | 88 +- docs/api/qiskit/transpiler.mdx | 30 +- docs/api/qiskit/transpiler_passes.mdx | 11 +- docs/api/qiskit/transpiler_plugins.mdx | 20 +- docs/api/qiskit/transpiler_preset.mdx | 28 +- docs/api/qiskit/utils.mdx | 46 +- docs/api/qiskit/visualization.mdx | 2 +- docs/build/bit-ordering.mdx | 2 +- docs/run/native-gates.mdx | 20 +- docs/start/hello-world.ipynb | 4 +- docs/support.mdx | 2 +- .../stabilizer-circuit-simulation.ipynb | 2 +- public/api/qiskit/1.0/objects.inv | Bin 0 -> 68345 bytes public/api/qiskit/dev/objects.inv | Bin 70005 -> 72292 bytes public/api/qiskit/objects.inv | Bin 68345 -> 72332 bytes public/images/api/qiskit/1.0/circuit-1.png | Bin 0 -> 5373 bytes public/images/api/qiskit/1.0/circuit-2.png | Bin 0 -> 3876 bytes public/images/api/qiskit/1.0/circuit-3.png | Bin 0 -> 5607 bytes public/images/api/qiskit/1.0/circuit-4.png | Bin 0 -> 29666 bytes public/images/api/qiskit/1.0/circuit-5.png | Bin 0 -> 8143 bytes .../api/qiskit/1.0/circuit_library-1.png | Bin 0 -> 6289 bytes public/images/api/qiskit/1.0/converters-1.png | Bin 0 -> 8320 bytes public/images/api/qiskit/1.0/depth.gif | Bin 0 -> 2874095 bytes public/images/api/qiskit/1.0/mapping.png | Bin 0 -> 60165 bytes .../1.0/providers_fake_provider-1_00.png | Bin 0 -> 13102 bytes .../1.0/providers_fake_provider-1_01.png | Bin 0 -> 22602 bytes .../1.0/providers_fake_provider-1_02.png | Bin 0 -> 14194 bytes public/images/api/qiskit/1.0/pulse-1.png | Bin 0 -> 31312 bytes public/images/api/qiskit/1.0/pulse-2.png | Bin 0 -> 10937 bytes public/images/api/qiskit/1.0/pulse-3.png | Bin 0 -> 59773 bytes public/images/api/qiskit/1.0/pulse-4.png | Bin 0 -> 18976 bytes public/images/api/qiskit/1.0/pulse-5.png | Bin 0 -> 16437 bytes public/images/api/qiskit/1.0/pulse-6.png | Bin 0 -> 11430 bytes public/images/api/qiskit/1.0/pulse-7.png | Bin 0 -> 14163 bytes public/images/api/qiskit/1.0/qasm3-1.png | Bin 0 -> 25489 bytes .../1.0/qiskit-circuit-ControlledGate-1.png | Bin 0 -> 4578 bytes .../1.0/qiskit-circuit-ControlledGate-2.png | Bin 0 -> 7249 bytes .../1.0/qiskit-circuit-InstructionSet-1.png | Bin 0 -> 8936 bytes .../qiskit/1.0/qiskit-circuit-Operation-1.png | Bin 0 -> 5879 bytes .../1.0/qiskit-circuit-Parameter-1_00.png | Bin 0 -> 1689 bytes .../1.0/qiskit-circuit-Parameter-1_01.png | Bin 0 -> 5370 bytes .../qiskit-circuit-QuantumCircuit-1.png | Bin .../qiskit-circuit-QuantumCircuit-2.png | Bin .../qiskit-circuit-QuantumCircuit-3_00.png | Bin .../qiskit-circuit-QuantumCircuit-3_01.png | Bin .../qiskit-circuit-QuantumCircuit-4_00.png | Bin .../qiskit-circuit-QuantumCircuit-4_01.png | Bin .../1.0/qiskit-circuit-QuantumCircuit-5.png | Bin 0 -> 3214 bytes .../qiskit-circuit-QuantumCircuit-6.png | Bin .../1.0/qiskit-circuit-library-AND-1.png | Bin 0 -> 16860 bytes .../1.0/qiskit-circuit-library-AND-2.png | Bin 0 -> 17615 bytes ...skit-circuit-library-FourierChecking-1.png | Bin 0 -> 11434 bytes .../1.0/qiskit-circuit-library-GMS-1.png | Bin 0 -> 13316 bytes .../1.0/qiskit-circuit-library-GR-1.png | Bin 0 -> 16936 bytes .../1.0/qiskit-circuit-library-GRX-1.png | Bin 0 -> 16876 bytes .../1.0/qiskit-circuit-library-GRY-1.png | Bin 0 -> 16936 bytes .../1.0/qiskit-circuit-library-GRZ-1.png | Bin 0 -> 12094 bytes .../qiskit-circuit-library-GraphState-1.png | Bin 0 -> 15678 bytes ...circuit-library-HiddenLinearFunction-1.png | Bin 0 -> 13076 bytes .../1.0/qiskit-circuit-library-IQP-1.png | Bin 0 -> 6597 bytes .../1.0/qiskit-circuit-library-IQP-2.png | Bin 0 -> 15203 bytes .../qiskit-circuit-library-InnerProduct-1.png | Bin 0 -> 14234 bytes .../qiskit-circuit-library-MCMTVChain-1.png | Bin 0 -> 14771 bytes .../1.0/qiskit-circuit-library-OR-1.png | Bin 0 -> 20577 bytes .../1.0/qiskit-circuit-library-OR-2.png | Bin 0 -> 18664 bytes ...iskit-circuit-library-PauliTwoDesign-1.png | Bin 0 -> 10538 bytes .../qiskit-circuit-library-Permutation-1.png | Bin 0 -> 9030 bytes .../qiskit-circuit-library-Permutation-2.png | Bin 0 -> 16568 bytes ...skit-circuit-library-PermutationGate-1.png | Bin 0 -> 7616 bytes ...skit-circuit-library-PermutationGate-2.png | Bin 0 -> 16133 bytes ...skit-circuit-library-PhaseEstimation-1.png | Bin 0 -> 12242 bytes ...t-circuit-library-PiecewiseChebyshev-1.png | Bin 0 -> 7636 bytes .../1.0/qiskit-circuit-library-QFT-1.png | Bin 0 -> 11836 bytes .../1.0/qiskit-circuit-library-QFT-2.png | Bin 0 -> 12001 bytes .../1.0/qiskit-circuit-library-QFT-3.png | Bin 0 -> 12100 bytes ...qiskit-circuit-library-QuantumVolume-1.png | Bin 0 -> 9389 bytes ...qiskit-circuit-library-QuantumVolume-2.png | Bin 0 -> 18255 bytes .../1.0/qiskit-circuit-library-XOR-1.png | Bin 0 -> 12259 bytes ...skit-primitives-StatevectorEstimator-1.png | Bin 0 -> 44937 bytes .../qiskit-pulse-library-SymbolicPulse-1.png | Bin 0 -> 11401 bytes .../1.0/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 ...skit-transpiler-passes-FilterOpNodes-1.png | Bin 0 -> 1637 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 -> 1593 bytes .../qiskit-visualization-circuit_drawer-1.png | Bin 0 -> 3214 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 -> 10065 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 -> 49253 bytes .../qiskit-visualization-plot_gate_map-1.png | Bin 0 -> 8595 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-timeline_drawer-1.png | Bin 0 -> 15985 bytes ...qiskit-visualization-timeline_drawer-2.png | Bin 0 -> 8474 bytes ...qiskit-visualization-timeline_drawer-3.png | Bin 0 -> 27012 bytes .../images/api/qiskit/1.0/transpiler-10.png | Bin 0 -> 7231 bytes .../images/api/qiskit/1.0/transpiler-11.png | Bin 0 -> 36154 bytes .../images/api/qiskit/1.0/transpiler-12.png | Bin 0 -> 8913 bytes .../images/api/qiskit/1.0/transpiler-13.png | Bin 0 -> 36154 bytes .../images/api/qiskit/1.0/transpiler-14.png | Bin 0 -> 20314 bytes .../images/api/qiskit/1.0/transpiler-15.png | Bin 0 -> 9699 bytes .../images/api/qiskit/1.0/transpiler-16.png | Bin 0 -> 24853 bytes .../images/api/qiskit/1.0/transpiler-17.png | Bin 0 -> 19159 bytes public/images/api/qiskit/1.0/transpiler-4.png | Bin 0 -> 6289 bytes public/images/api/qiskit/1.0/transpiler-5.png | Bin 0 -> 20199 bytes public/images/api/qiskit/1.0/transpiler-6.png | Bin 0 -> 10473 bytes public/images/api/qiskit/1.0/transpiler-7.png | Bin 0 -> 12152 bytes public/images/api/qiskit/1.0/transpiler-8.png | Bin 0 -> 7725 bytes public/images/api/qiskit/1.0/transpiler-9.png | Bin 0 -> 7662 bytes .../api/qiskit/1.0/transpiling_core_steps.png | Bin 0 -> 246632 bytes .../images/api/qiskit/1.0/visualization-1.png | Bin 0 -> 10426 bytes .../images/api/qiskit/1.0/visualization-2.png | Bin 0 -> 17293 bytes .../images/api/qiskit/1.0/visualization-3.png | Bin 0 -> 10033 bytes .../images/api/qiskit/1.0/visualization-4.png | Bin 0 -> 108756 bytes .../images/api/qiskit/1.0/visualization-5.png | Bin 0 -> 113083 bytes .../images/api/qiskit/1.0/visualization-6.png | Bin 0 -> 113083 bytes public/images/api/qiskit/circuit-1.png | Bin 5373 -> 5373 bytes public/images/api/qiskit/circuit-2.png | Bin 3876 -> 8049 bytes public/images/api/qiskit/circuit-4.png | Bin 29666 -> 13896 bytes .../images/api/qiskit/circuit_library-1.png | Bin 6289 -> 6289 bytes public/images/api/qiskit/converters-1.png | Bin 8320 -> 8320 bytes public/images/api/qiskit/dev/circuit-1.png | Bin 5373 -> 5373 bytes public/images/api/qiskit/dev/circuit-2.png | Bin 29666 -> 9580 bytes public/images/api/qiskit/dev/circuit-3.png | Bin 9531 -> 0 bytes .../dev/{circuit-5.png => circuit-4.png} | Bin 13896 -> 13896 bytes .../api/qiskit/dev/circuit_library-1.png | Bin 6289 -> 6289 bytes public/images/api/qiskit/dev/converters-1.png | Bin 8320 -> 8320 bytes .../dev/providers_fake_provider-1_00.png | Bin 13102 -> 13102 bytes .../dev/providers_fake_provider-1_01.png | Bin 22602 -> 22602 bytes .../dev/providers_fake_provider-1_02.png | Bin 10966 -> 10848 bytes public/images/api/qiskit/dev/pulse-1.png | Bin 31312 -> 31312 bytes public/images/api/qiskit/dev/pulse-2.png | Bin 10944 -> 10930 bytes public/images/api/qiskit/dev/pulse-3.png | Bin 59802 -> 59725 bytes public/images/api/qiskit/dev/pulse-4.png | Bin 18925 -> 19023 bytes public/images/api/qiskit/dev/pulse-5.png | Bin 16261 -> 16353 bytes public/images/api/qiskit/dev/pulse-6.png | Bin 11354 -> 11184 bytes public/images/api/qiskit/dev/pulse-7.png | Bin 14079 -> 14090 bytes public/images/api/qiskit/dev/qasm3-1.png | Bin 25489 -> 25489 bytes .../dev/qiskit-circuit-ControlledGate-1.png | Bin 4578 -> 4578 bytes .../dev/qiskit-circuit-ControlledGate-2.png | Bin 7180 -> 6949 bytes .../qiskit/dev/qiskit-circuit-Operation-1.png | Bin 5879 -> 5879 bytes .../dev/qiskit-circuit-Parameter-1_00.png | Bin 1689 -> 1689 bytes .../dev/qiskit-circuit-Parameter-1_01.png | Bin 5370 -> 5370 bytes .../qiskit-circuit-QuantumCircuit-1_00.png | Bin 0 -> 3661 bytes .../qiskit-circuit-QuantumCircuit-1_01.png | Bin 0 -> 3635 bytes .../qiskit-circuit-QuantumCircuit-2_00.png | Bin 0 -> 3585 bytes .../qiskit-circuit-QuantumCircuit-2_01.png | Bin 0 -> 3913 bytes .../dev/qiskit-circuit-QuantumCircuit-3.png | Bin 0 -> 4256 bytes .../dev/qiskit-circuit-QuantumCircuit-4.png | Bin 0 -> 29666 bytes .../dev/qiskit-circuit-QuantumCircuit-5.png | Bin 3214 -> 3214 bytes .../dev/qiskit-circuit-library-AND-1.png | Bin 16860 -> 16860 bytes .../dev/qiskit-circuit-library-AND-2.png | Bin 17615 -> 17615 bytes ...skit-circuit-library-FourierChecking-1.png | Bin 11434 -> 11434 bytes .../dev/qiskit-circuit-library-GMS-1.png | Bin 13316 -> 13316 bytes .../dev/qiskit-circuit-library-GR-1.png | Bin 16936 -> 16936 bytes .../dev/qiskit-circuit-library-GRX-1.png | Bin 16876 -> 16876 bytes .../dev/qiskit-circuit-library-GRY-1.png | Bin 16936 -> 16936 bytes .../dev/qiskit-circuit-library-GRZ-1.png | Bin 12094 -> 12094 bytes .../qiskit-circuit-library-GraphState-1.png | Bin 15678 -> 15678 bytes ...circuit-library-HiddenLinearFunction-1.png | Bin 13076 -> 13076 bytes .../dev/qiskit-circuit-library-IQP-1.png | Bin 6597 -> 6597 bytes .../dev/qiskit-circuit-library-IQP-2.png | Bin 15203 -> 15203 bytes .../qiskit-circuit-library-InnerProduct-1.png | Bin 14234 -> 14234 bytes .../qiskit-circuit-library-MCMTVChain-1.png | Bin 14771 -> 14771 bytes .../dev/qiskit-circuit-library-OR-1.png | Bin 20577 -> 20577 bytes .../dev/qiskit-circuit-library-OR-2.png | Bin 18664 -> 18664 bytes ...iskit-circuit-library-PauliTwoDesign-1.png | Bin 10538 -> 10538 bytes .../qiskit-circuit-library-Permutation-1.png | Bin 9030 -> 9030 bytes .../qiskit-circuit-library-Permutation-2.png | Bin 16568 -> 16568 bytes ...skit-circuit-library-PermutationGate-1.png | Bin 7616 -> 7616 bytes ...skit-circuit-library-PermutationGate-2.png | Bin 15921 -> 15942 bytes ...skit-circuit-library-PhaseEstimation-1.png | Bin 12207 -> 12212 bytes ...t-circuit-library-PiecewiseChebyshev-1.png | Bin 7636 -> 7636 bytes .../dev/qiskit-circuit-library-QFT-1.png | Bin 11836 -> 11836 bytes .../dev/qiskit-circuit-library-QFT-2.png | Bin 12001 -> 12001 bytes .../dev/qiskit-circuit-library-QFT-3.png | Bin 12100 -> 12100 bytes ...qiskit-circuit-library-QuantumVolume-1.png | Bin 9389 -> 9389 bytes ...qiskit-circuit-library-QuantumVolume-2.png | Bin 20781 -> 20781 bytes .../dev/qiskit-circuit-library-XOR-1.png | Bin 12259 -> 12259 bytes ...skit-primitives-StatevectorEstimator-1.png | Bin 44937 -> 43580 bytes .../qiskit-pulse-library-SymbolicPulse-1.png | Bin 11401 -> 11401 bytes .../dev/qiskit-quantum_info-Statevector-1.png | Bin 7558 -> 7558 bytes ...spiler-passes-DynamicalDecoupling-1_00.png | Bin 22803 -> 22803 bytes ...spiler-passes-DynamicalDecoupling-1_01.png | Bin 23583 -> 23583 bytes ...skit-transpiler-passes-FilterOpNodes-1.png | Bin 1637 -> 1637 bytes ...ler-passes-PadDynamicalDecoupling-1_00.png | Bin 22803 -> 22803 bytes ...ler-passes-PadDynamicalDecoupling-1_01.png | Bin 23583 -> 23583 bytes ...kit-transpiler-passes-RemoveBarriers-1.png | Bin 1593 -> 1593 bytes ...kit-transpiler-passes-StarPreRouting-1.png | Bin 49789 -> 49789 bytes .../qiskit-visualization-circuit_drawer-1.png | Bin 3214 -> 3214 bytes ...visualization-plot_bloch_multivector-1.png | Bin 92847 -> 97054 bytes ...visualization-plot_bloch_multivector-2.png | Bin 95603 -> 99845 bytes ...skit-visualization-plot_bloch_vector-1.png | Bin 73448 -> 76275 bytes ...skit-visualization-plot_bloch_vector-2.png | Bin 74554 -> 77587 bytes ...it-visualization-plot_circuit_layout-1.png | Bin 10094 -> 10184 bytes ...skit-visualization-plot_coupling_map-1.png | Bin 8007 -> 8007 bytes ...t-visualization-plot_distribution-1_00.png | Bin 14124 -> 14124 bytes ...t-visualization-plot_distribution-1_01.png | Bin 16685 -> 16685 bytes ...t-visualization-plot_distribution-1_02.png | Bin 16681 -> 16681 bytes .../qiskit-visualization-plot_error_map-1.png | Bin 49236 -> 49664 bytes .../qiskit-visualization-plot_gate_map-1.png | Bin 8595 -> 8595 bytes ...skit-visualization-plot_histogram-1_00.png | Bin 10255 -> 10255 bytes ...skit-visualization-plot_histogram-1_01.png | Bin 12587 -> 12587 bytes ...skit-visualization-plot_histogram-1_02.png | Bin 12639 -> 12639 bytes ...qiskit-visualization-plot_state_city-1.png | Bin 117324 -> 115263 bytes ...qiskit-visualization-plot_state_city-2.png | Bin 159875 -> 160318 bytes ...skit-visualization-plot_state_hinton-1.png | Bin 11116 -> 11116 bytes ...it-visualization-plot_state_paulivec-1.png | Bin 17337 -> 17337 bytes ...it-visualization-plot_state_paulivec-2.png | Bin 18522 -> 18522 bytes ...kit-visualization-plot_state_qsphere-1.png | Bin 33861 -> 35058 bytes ...kit-visualization-plot_state_qsphere-2.png | Bin 38572 -> 39591 bytes ...qiskit-visualization-timeline_drawer-1.png | Bin 16070 -> 16080 bytes ...qiskit-visualization-timeline_drawer-2.png | Bin 8002 -> 8282 bytes ...qiskit-visualization-timeline_drawer-3.png | Bin 27461 -> 26305 bytes .../images/api/qiskit/dev/release_notes-1.png | Bin 13722 -> 4723 bytes .../images/api/qiskit/dev/release_notes-2.png | Bin 11731 -> 13722 bytes .../images/api/qiskit/dev/release_notes-3.png | Bin 8695 -> 11731 bytes .../images/api/qiskit/dev/release_notes-4.png | Bin 7530 -> 8695 bytes .../images/api/qiskit/dev/release_notes-5.png | Bin 7069 -> 7530 bytes .../images/api/qiskit/dev/release_notes-6.png | Bin 0 -> 7069 bytes .../images/api/qiskit/dev/transpiler-10.png | Bin 7231 -> 7413 bytes .../images/api/qiskit/dev/transpiler-11.png | Bin 36154 -> 36154 bytes .../images/api/qiskit/dev/transpiler-12.png | Bin 8913 -> 8913 bytes .../images/api/qiskit/dev/transpiler-13.png | Bin 36154 -> 36154 bytes .../images/api/qiskit/dev/transpiler-14.png | Bin 20314 -> 20314 bytes .../images/api/qiskit/dev/transpiler-15.png | Bin 9699 -> 9699 bytes .../images/api/qiskit/dev/transpiler-16.png | Bin 24950 -> 24353 bytes .../images/api/qiskit/dev/transpiler-17.png | Bin 19211 -> 18789 bytes public/images/api/qiskit/dev/transpiler-4.png | Bin 6289 -> 6289 bytes public/images/api/qiskit/dev/transpiler-5.png | Bin 20199 -> 20199 bytes public/images/api/qiskit/dev/transpiler-6.png | Bin 10473 -> 10473 bytes public/images/api/qiskit/dev/transpiler-7.png | Bin 12152 -> 12152 bytes public/images/api/qiskit/dev/transpiler-8.png | Bin 7725 -> 7454 bytes public/images/api/qiskit/dev/transpiler-9.png | Bin 7662 -> 7385 bytes .../images/api/qiskit/dev/visualization-1.png | Bin 8219 -> 8219 bytes .../images/api/qiskit/dev/visualization-2.png | Bin 15392 -> 15392 bytes .../images/api/qiskit/dev/visualization-3.png | Bin 7806 -> 7806 bytes .../images/api/qiskit/dev/visualization-4.png | Bin 108756 -> 108711 bytes .../images/api/qiskit/dev/visualization-5.png | Bin 113083 -> 111196 bytes .../images/api/qiskit/dev/visualization-6.png | Bin 113083 -> 111196 bytes .../qiskit/providers_fake_provider-1_00.png | Bin 13102 -> 13102 bytes .../qiskit/providers_fake_provider-1_01.png | Bin 22602 -> 22602 bytes .../qiskit/providers_fake_provider-1_02.png | Bin 14194 -> 10890 bytes public/images/api/qiskit/pulse-1.png | Bin 31312 -> 31312 bytes public/images/api/qiskit/pulse-2.png | Bin 10937 -> 10909 bytes public/images/api/qiskit/pulse-3.png | Bin 59773 -> 59801 bytes public/images/api/qiskit/pulse-4.png | Bin 18976 -> 18873 bytes public/images/api/qiskit/pulse-5.png | Bin 16437 -> 16178 bytes public/images/api/qiskit/pulse-6.png | Bin 11430 -> 11300 bytes public/images/api/qiskit/pulse-7.png | Bin 14163 -> 14016 bytes public/images/api/qiskit/qasm3-1.png | Bin 25489 -> 25489 bytes .../qiskit-circuit-ControlledGate-1.png | Bin 4578 -> 3932 bytes .../qiskit-circuit-ControlledGate-2.png | Bin 7249 -> 6983 bytes .../api/qiskit/qiskit-circuit-Operation-1.png | Bin 5879 -> 5879 bytes .../qiskit/qiskit-circuit-Parameter-1_00.png | Bin 1689 -> 1689 bytes .../qiskit/qiskit-circuit-Parameter-1_01.png | Bin 5370 -> 5370 bytes .../qiskit-circuit-QuantumCircuit-1_00.png | Bin 0 -> 3661 bytes .../qiskit-circuit-QuantumCircuit-1_01.png | Bin 0 -> 3635 bytes .../qiskit-circuit-QuantumCircuit-2_00.png | Bin 0 -> 3585 bytes .../qiskit-circuit-QuantumCircuit-2_01.png | Bin 0 -> 3913 bytes .../qiskit-circuit-QuantumCircuit-3.png | Bin 0 -> 4256 bytes .../qiskit-circuit-QuantumCircuit-4.png | Bin 0 -> 29666 bytes .../qiskit-circuit-QuantumCircuit-5.png | Bin 3214 -> 3214 bytes .../qiskit/qiskit-circuit-library-AND-1.png | Bin 16860 -> 16860 bytes .../qiskit/qiskit-circuit-library-AND-2.png | Bin 17615 -> 17615 bytes ...skit-circuit-library-FourierChecking-1.png | Bin 11434 -> 11434 bytes .../qiskit/qiskit-circuit-library-GMS-1.png | Bin 13316 -> 13316 bytes .../qiskit/qiskit-circuit-library-GR-1.png | Bin 16936 -> 16936 bytes .../qiskit/qiskit-circuit-library-GRX-1.png | Bin 16876 -> 16876 bytes .../qiskit/qiskit-circuit-library-GRY-1.png | Bin 16936 -> 16936 bytes .../qiskit/qiskit-circuit-library-GRZ-1.png | Bin 12094 -> 12094 bytes .../qiskit-circuit-library-GraphState-1.png | Bin 15678 -> 15678 bytes ...circuit-library-HiddenLinearFunction-1.png | Bin 13076 -> 13076 bytes .../qiskit/qiskit-circuit-library-IQP-1.png | Bin 6597 -> 6597 bytes .../qiskit/qiskit-circuit-library-IQP-2.png | Bin 15203 -> 15203 bytes .../qiskit-circuit-library-InnerProduct-1.png | Bin 14234 -> 14234 bytes .../qiskit-circuit-library-MCMTVChain-1.png | Bin 14771 -> 14771 bytes .../qiskit/qiskit-circuit-library-OR-1.png | Bin 20577 -> 20577 bytes .../qiskit/qiskit-circuit-library-OR-2.png | Bin 18664 -> 18664 bytes ...iskit-circuit-library-PauliTwoDesign-1.png | Bin 10538 -> 10538 bytes .../qiskit-circuit-library-Permutation-1.png | Bin 9030 -> 9030 bytes .../qiskit-circuit-library-Permutation-2.png | Bin 16568 -> 16568 bytes ...skit-circuit-library-PermutationGate-1.png | Bin 7616 -> 7616 bytes ...skit-circuit-library-PermutationGate-2.png | Bin 16133 -> 16090 bytes ...skit-circuit-library-PhaseEstimation-1.png | Bin 12242 -> 12212 bytes ...t-circuit-library-PiecewiseChebyshev-1.png | Bin 7636 -> 7636 bytes .../qiskit/qiskit-circuit-library-QFT-1.png | Bin 11836 -> 11836 bytes .../qiskit/qiskit-circuit-library-QFT-2.png | Bin 12001 -> 12001 bytes .../qiskit/qiskit-circuit-library-QFT-3.png | Bin 12100 -> 12100 bytes ...qiskit-circuit-library-QuantumVolume-1.png | Bin 9389 -> 9389 bytes ...qiskit-circuit-library-QuantumVolume-2.png | Bin 18255 -> 20781 bytes .../qiskit/qiskit-circuit-library-XOR-1.png | Bin 12259 -> 12259 bytes ...skit-primitives-StatevectorEstimator-1.png | Bin 44937 -> 43580 bytes .../qiskit-pulse-library-SymbolicPulse-1.png | Bin 11401 -> 11401 bytes .../qiskit-quantum_info-Statevector-1.png | Bin 7558 -> 7558 bytes ...spiler-passes-DynamicalDecoupling-1_00.png | Bin 22803 -> 22803 bytes ...spiler-passes-DynamicalDecoupling-1_01.png | Bin 23583 -> 23583 bytes ...skit-transpiler-passes-FilterOpNodes-1.png | Bin 1637 -> 1637 bytes ...ler-passes-PadDynamicalDecoupling-1_00.png | Bin 22803 -> 22803 bytes ...ler-passes-PadDynamicalDecoupling-1_01.png | Bin 23583 -> 23583 bytes ...kit-transpiler-passes-RemoveBarriers-1.png | Bin 1593 -> 1593 bytes ...kit-transpiler-passes-StarPreRouting-1.png | Bin 0 -> 49789 bytes .../qiskit-visualization-circuit_drawer-1.png | Bin 3214 -> 3214 bytes ...visualization-plot_bloch_multivector-1.png | Bin 92847 -> 97054 bytes ...visualization-plot_bloch_multivector-2.png | Bin 95603 -> 99845 bytes ...skit-visualization-plot_bloch_vector-1.png | Bin 73448 -> 76275 bytes ...skit-visualization-plot_bloch_vector-2.png | Bin 74554 -> 77587 bytes ...it-visualization-plot_circuit_layout-1.png | Bin 10065 -> 10092 bytes ...skit-visualization-plot_coupling_map-1.png | Bin 8007 -> 8007 bytes ...t-visualization-plot_distribution-1_00.png | Bin 16020 -> 14124 bytes ...t-visualization-plot_distribution-1_01.png | Bin 20219 -> 16685 bytes ...t-visualization-plot_distribution-1_02.png | Bin 20276 -> 16681 bytes .../qiskit-visualization-plot_error_map-1.png | Bin 49253 -> 49873 bytes .../qiskit-visualization-plot_gate_map-1.png | Bin 8595 -> 8595 bytes ...skit-visualization-plot_histogram-1_00.png | Bin 12434 -> 10255 bytes ...skit-visualization-plot_histogram-1_01.png | Bin 16199 -> 12587 bytes ...skit-visualization-plot_histogram-1_02.png | Bin 16249 -> 12639 bytes ...qiskit-visualization-plot_state_city-1.png | Bin 117324 -> 115263 bytes ...qiskit-visualization-plot_state_city-2.png | Bin 159875 -> 160318 bytes ...skit-visualization-plot_state_hinton-1.png | Bin 11116 -> 11116 bytes ...it-visualization-plot_state_paulivec-1.png | Bin 17337 -> 17337 bytes ...it-visualization-plot_state_paulivec-2.png | Bin 18522 -> 18522 bytes ...kit-visualization-plot_state_qsphere-1.png | Bin 33861 -> 35058 bytes ...kit-visualization-plot_state_qsphere-2.png | Bin 38572 -> 39591 bytes ...qiskit-visualization-timeline_drawer-1.png | Bin 15985 -> 15845 bytes ...qiskit-visualization-timeline_drawer-2.png | Bin 8474 -> 7855 bytes ...qiskit-visualization-timeline_drawer-3.png | Bin 27012 -> 26932 bytes public/images/api/qiskit/release_notes-1.png | Bin 7069 -> 13722 bytes public/images/api/qiskit/release_notes-2.png | Bin 0 -> 11731 bytes public/images/api/qiskit/release_notes-3.png | Bin 0 -> 8695 bytes public/images/api/qiskit/release_notes-4.png | Bin 0 -> 7530 bytes public/images/api/qiskit/release_notes-5.png | Bin 0 -> 21767 bytes public/images/api/qiskit/release_notes-6.png | Bin 0 -> 11654 bytes public/images/api/qiskit/release_notes-7.png | Bin 0 -> 14081 bytes public/images/api/qiskit/transpiler-10.png | Bin 7231 -> 7413 bytes public/images/api/qiskit/transpiler-11.png | Bin 36154 -> 36154 bytes public/images/api/qiskit/transpiler-12.png | Bin 8913 -> 8913 bytes public/images/api/qiskit/transpiler-13.png | Bin 36154 -> 36154 bytes public/images/api/qiskit/transpiler-14.png | Bin 20314 -> 20314 bytes public/images/api/qiskit/transpiler-15.png | Bin 9699 -> 9699 bytes public/images/api/qiskit/transpiler-16.png | Bin 24853 -> 24926 bytes public/images/api/qiskit/transpiler-17.png | Bin 19159 -> 19096 bytes public/images/api/qiskit/transpiler-4.png | Bin 6289 -> 6289 bytes public/images/api/qiskit/transpiler-5.png | Bin 20199 -> 20199 bytes public/images/api/qiskit/transpiler-6.png | Bin 10473 -> 10473 bytes public/images/api/qiskit/transpiler-7.png | Bin 12152 -> 12152 bytes public/images/api/qiskit/transpiler-8.png | Bin 7725 -> 7454 bytes public/images/api/qiskit/transpiler-9.png | Bin 7662 -> 7385 bytes public/images/api/qiskit/visualization-1.png | Bin 10426 -> 8219 bytes public/images/api/qiskit/visualization-2.png | Bin 17293 -> 15392 bytes public/images/api/qiskit/visualization-3.png | Bin 10033 -> 7806 bytes public/images/api/qiskit/visualization-4.png | Bin 108756 -> 108711 bytes public/images/api/qiskit/visualization-5.png | Bin 113083 -> 111196 bytes public/images/api/qiskit/visualization-6.png | Bin 113083 -> 111196 bytes scripts/api-html-artifacts.json | 3 +- scripts/commands/checkInternalLinks.ts | 3 + scripts/commands/checkOrphanPages.ts | 5 +- scripts/lib/api/TocGrouping.test.ts | 2 +- scripts/lib/links/ignores.ts | 19 +- 1925 files changed, 113708 insertions(+), 10661 deletions(-) create mode 100644 docs/api/qiskit/1.0/_package.json create mode 100644 docs/api/qiskit/1.0/_toc.json create mode 100644 docs/api/qiskit/1.0/assembler.mdx create mode 100644 docs/api/qiskit/1.0/circuit.mdx create mode 100644 docs/api/qiskit/1.0/circuit_classical.mdx create mode 100644 docs/api/qiskit/1.0/circuit_library.mdx create mode 100644 docs/api/qiskit/1.0/circuit_singleton.mdx create mode 100644 docs/api/qiskit/1.0/classicalfunction.mdx create mode 100644 docs/api/qiskit/1.0/compiler.mdx create mode 100644 docs/api/qiskit/1.0/converters.mdx create mode 100644 docs/api/qiskit/1.0/dagcircuit.mdx create mode 100644 docs/api/qiskit/1.0/exceptions.mdx create mode 100644 docs/api/qiskit/1.0/index.mdx create mode 100644 docs/api/qiskit/1.0/passmanager.mdx create mode 100644 docs/api/qiskit/1.0/primitives.mdx create mode 100644 docs/api/qiskit/1.0/providers.mdx create mode 100644 docs/api/qiskit/1.0/providers_basic_provider.mdx create mode 100644 docs/api/qiskit/1.0/providers_fake_provider.mdx create mode 100644 docs/api/qiskit/1.0/providers_models.mdx create mode 100644 docs/api/qiskit/1.0/pulse.mdx create mode 100644 docs/api/qiskit/1.0/qasm2.mdx create mode 100644 docs/api/qiskit/1.0/qasm3.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.assembler.RunConfig.mdx rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.AncillaQubit.mdx (100%) rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.AncillaRegister.mdx (100%) create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.AnnotatedOperation.mdx rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.Bit.mdx (100%) create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.BreakLoopOp.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.CircuitInstruction.mdx rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.ClassicalRegister.mdx (100%) rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.Clbit.mdx (100%) rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.CommutationChecker.mdx (100%) create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.ContinueLoopOp.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.ControlFlowOp.mdx rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.ControlModifier.mdx (100%) create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.ControlledGate.mdx rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.Delay.mdx (100%) create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.EquivalenceLibrary.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.ForLoopOp.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.Gate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.IfElseOp.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.Instruction.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.InstructionSet.mdx rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.InverseModifier.mdx (100%) create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.Operation.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.Parameter.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.ParameterExpression.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.ParameterVector.mdx rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.PowerModifier.mdx (100%) create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.QuantumCircuit.mdx rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.QuantumRegister.mdx (100%) rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.Qubit.mdx (100%) rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.Register.mdx (100%) create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.SwitchCaseOp.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.WhileLoopOp.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.BooleanExpression.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.ClassicalFunction.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.AND.mdx rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.library.Barrier.mdx (100%) create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.C3SXGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.C3XGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.C4XGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CCXGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CCZGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CDKMRippleCarryAdder.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CHGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CPhaseGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CRXGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CRYGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CRZGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CSGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CSXGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CSdgGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CSwapGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CU1Gate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CU3Gate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CUGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CXGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CYGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.CZGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.DCXGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.Diagonal.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.DiagonalGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.DraperQFTAdder.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.ECRGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.EfficientSU2.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.EvolvedOperatorAnsatz.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.ExactReciprocal.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.ExcitationPreserving.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.FourierChecking.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.FunctionalPauliRotations.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.GMS.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.GR.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.GRX.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.GRY.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.GRZ.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.GlobalPhaseGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.GraphState.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.GroverOperator.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.HGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.HRSCumulativeMultiplier.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.HamiltonianGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.HiddenLinearFunction.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.IGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.IQP.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.Initialize.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.InnerProduct.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.IntegerComparator.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.Isometry.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.LinearAmplitudeFunction.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.LinearFunction.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.LinearPauliRotations.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.MCMT.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.MCMTVChain.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.MCPhaseGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.MCXGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.MCXGrayCode.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.MCXRecursive.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.MCXVChain.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.MSGate.mdx rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.library.Measure.mdx (100%) create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.NLocal.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.OR.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.PauliEvolutionGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.PauliFeatureMap.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.PauliGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.PauliTwoDesign.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.Permutation.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.PermutationGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.PhaseEstimation.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.PhaseGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.PhaseOracle.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.PiecewiseChebyshev.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.PiecewiseLinearPauliRotations.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.PiecewisePolynomialPauliRotations.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.PolynomialPauliRotations.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.QAOAAnsatz.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.QFT.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.QuadraticForm.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.QuantumVolume.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.RC3XGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.RCCXGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.RGQFTMultiplier.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.RGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.RVGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.RXGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.RXXGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.RYGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.RYYGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.RZGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.RZXGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.RZZGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.RealAmplitudes.mdx rename docs/api/qiskit/{ => 1.0}/qiskit.circuit.library.Reset.mdx (100%) create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.SGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.SXGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.SXdgGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.SdgGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.StatePreparation.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.SwapGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.TGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.TdgGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.TwoLocal.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.U1Gate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.U2Gate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.U3Gate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.UCGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.UCPauliRotGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.UCRXGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.UCRYGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.UCRZGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.UGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.UnitaryGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.UnitaryOverlap.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.VBERippleCarryAdder.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.WeightedAdder.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.XGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.XOR.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.XXMinusYYGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.XXPlusYYGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.YGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.ZFeatureMap.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.ZGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.ZZFeatureMap.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.circuit.library.iSwapGate.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.dagcircuit.DAGCircuit.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.dagcircuit.DAGDepNode.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.dagcircuit.DAGDependency.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.dagcircuit.DAGInNode.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.dagcircuit.DAGNode.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.dagcircuit.DAGOpNode.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.dagcircuit.DAGOutNode.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.passmanager.BaseController.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.passmanager.BasePassManager.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.passmanager.ConditionalController.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.passmanager.DoWhileController.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.passmanager.FlowControllerLinear.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.passmanager.GenericPass.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.passmanager.PassManagerState.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.passmanager.PropertySet.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.passmanager.WorkflowStatus.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.BackendEstimator.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.BackendSampler.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.BaseEstimator.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.BaseEstimatorV1.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.BaseEstimatorV2.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.BasePrimitiveJob.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.BaseSampler.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.BaseSamplerV1.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.BaseSamplerV2.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.BitArray.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.DataBin.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.Estimator.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.EstimatorResult.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.PrimitiveJob.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.PrimitiveResult.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.PubResult.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.Sampler.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.SamplerResult.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.StatevectorEstimator.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.primitives.StatevectorSampler.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.Backend.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.BackendV1.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.BackendV2.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.BackendV2Converter.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.Job.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.JobStatus.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.JobV1.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.Options.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.Provider.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.ProviderV1.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.QubitProperties.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.basic_provider.BasicProvider.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.basic_provider.BasicProviderError.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.basic_provider.BasicProviderJob.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.basic_provider.BasicSimulator.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.convert_to_target.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake127QPulseV1.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake1Q.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake20QV1.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake27QPulseV1.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake5QV1.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake7QPulseV1.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.fake_provider.FakeOpenPulse2Q.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.fake_provider.FakeOpenPulse3Q.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.fake_provider.GenericBackendV2.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.models.BackendConfiguration.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.models.BackendProperties.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.models.BackendStatus.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.models.Command.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.models.GateConfig.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.models.GateProperties.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.models.JobStatus.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.models.Nduv.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.models.PulseBackendConfiguration.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.models.PulseDefaults.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.models.QasmBackendConfiguration.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.providers.models.UchannelLO.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.InstructionScheduleMap.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.Schedule.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.ScheduleBlock.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.channels.AcquireChannel.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.channels.ControlChannel.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.channels.DriveChannel.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.channels.MeasureChannel.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.channels.MemorySlot.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.channels.RegisterSlot.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.channels.SnapshotChannel.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.instructions.Acquire.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.instructions.Delay.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.instructions.Play.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.instructions.Reference.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.instructions.RelativeBarrier.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.instructions.SetFrequency.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.instructions.SetPhase.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.instructions.ShiftFrequency.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.instructions.ShiftPhase.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.instructions.Snapshot.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.instructions.TimeBlockade.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.Constant_class.rst.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.Cos_class.rst.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.Drag_class.rst.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.GaussianDeriv.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.GaussianSquare.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.GaussianSquareDrag.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.Gaussian_class.rst.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.Sawtooth_class.rst.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.SechDeriv.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.Sech_fun.rst.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.Sin_class.rst.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.Square_fun.rst.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.SymbolicPulse.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.Triangle_class.rst.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.Waveform.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.library.gaussian_square_echo.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignEquispaced.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignFunc.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignLeft.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignRight.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignSequential.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.GateCalibration.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.PulseLibraryItem.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.PulseQobj.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.PulseQobjConfig.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.PulseQobjExperiment.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.PulseQobjExperimentConfig.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.PulseQobjInstruction.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.QasmExperimentCalibrations.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.QasmQobj.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.QasmQobjConfig.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.QasmQobjExperiment.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.QasmQobjExperimentConfig.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.QasmQobjInstruction.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.QobjExperimentHeader.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.QobjHeader.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.qobj.QobjMeasurementOption.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.CNOTDihedral.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.Chi.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.Choi.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.Clifford.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.DensityMatrix.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.Kraus.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.Operator.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.PTM.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.Pauli.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.PauliList.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.Quaternion.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.ScalarOp.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.SparsePauliOp.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.StabilizerState.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.Statevector.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.Stinespring.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.SuperOp.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.Z2Symmetries.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.quantum_info.pauli_basis.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.result.BaseReadoutMitigator.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.result.CorrelatedReadoutMitigator.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.result.Counts.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.result.LocalReadoutMitigator.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.result.ProbDistribution.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.result.QuasiDistribution.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.result.Result.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.result.ResultError.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.EvolutionSynthesis.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.LieTrotter.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.MatrixExponential.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.OneQubitEulerDecomposer.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.ProductFormula.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.QDrift.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.SolovayKitaevDecomposition.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.SuzukiTrotter.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.TwoQubitBasisDecomposer.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.TwoQubitWeylDecomposition.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.XXDecomposer.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.AQC.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.ApproximateCircuit.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.ApproximatingObjective.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.AnalysisPass.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.CouplingMap.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.InstructionDurations.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.InstructionProperties.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.Layout.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.PassManager.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.PassManagerConfig.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.StagedPassManager.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.Target.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.TransformationPass.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.TranspileLayout.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.ALAPSchedule.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.ALAPScheduleAnalysis.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.ASAPSchedule.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.ASAPScheduleAnalysis.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.AlignMeasures.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.ApplyLayout.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.BasicSwap.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.BasisTranslator.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.CSPLayout.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.CXCancellation.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.CheckGateDirection.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.CheckMap.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.Collect1qRuns.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.Collect2qBlocks.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.CollectCliffords.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.CollectLinearFunctions.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.CollectMultiQBlocks.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.CommutationAnalysis.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.CommutativeCancellation.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.CommutativeInverseCancellation.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.Commuting2qGateRouter.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.ConsolidateBlocks.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.ConstrainedReschedule.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.ContainsInstruction.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.ConvertConditionsToIfOps.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.CountOps.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.CountOpsLongestPath.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.DAGFixedPoint.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.DAGLongestPath.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.Decompose.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.DenseLayout.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.Depth.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.DynamicalDecoupling.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.EchoRZXWeylDecomposition.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.EnlargeWithAncilla.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.FilterOpNodes.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.FixedPoint.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.FullAncillaAllocation.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.GateDirection.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.GatesInBasis.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.HLSConfig.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.HighLevelSynthesis.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.HoareOptimizer.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.InstructionDurationCheck.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.InverseCancellation.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.Layout2qDistance.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.LinearFunctionsToPermutations.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.LookaheadSwap.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.MergeAdjacentBarriers.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.MinimumPoint.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.NormalizeRXAngle.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.NumTensorFactors.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.Optimize1qGates.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.Optimize1qGatesDecomposition.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.OptimizeAnnotated.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.OptimizeCliffords.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.PadDelay.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.PadDynamicalDecoupling.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.PulseGates.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.RXCalibrationBuilder.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.RZXCalibrationBuilder.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.RemoveBarriers.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.RemoveFinalMeasurements.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.RemoveResetInZeroState.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.ResetAfterMeasureSimplification.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.SabreLayout.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.SabrePreLayout.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.SabreSwap.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.SetIOLatency.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.SetLayout.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.Size.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.SolovayKitaev.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.StochasticSwap.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.TemplateOptimization.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.TimeUnitConversion.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.TranslateParameterizedGates.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.TrivialLayout.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.UnitarySynthesis.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.Unroll3qOrMore.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.UnrollCustomDefinitions.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.UnrollForLoops.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.VF2Layout.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.VF2PostLayout.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.ValidatePulseGates.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.Width.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.array_to_latex.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.circuit_drawer.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.dag_drawer.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.pass_manager_drawer.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.plot_bloch_multivector.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.plot_bloch_vector.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.plot_circuit_layout.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.plot_coupling_map.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.plot_distribution.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.plot_error_map.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.plot_gate_map.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.plot_histogram.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.plot_state_city.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.plot_state_hinton.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.plot_state_paulivec.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.plot_state_qsphere.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.timeline_drawer.mdx create mode 100644 docs/api/qiskit/1.0/qiskit.visualization.visualize_transition.mdx create mode 100644 docs/api/qiskit/1.0/qobj.mdx create mode 100644 docs/api/qiskit/1.0/qpy.mdx create mode 100644 docs/api/qiskit/1.0/quantum_info.mdx create mode 100644 docs/api/qiskit/1.0/result.mdx create mode 100644 docs/api/qiskit/1.0/scheduler.mdx create mode 100644 docs/api/qiskit/1.0/synthesis.mdx create mode 100644 docs/api/qiskit/1.0/transpiler.mdx create mode 100644 docs/api/qiskit/1.0/transpiler_passes.mdx create mode 100644 docs/api/qiskit/1.0/transpiler_plugins.mdx create mode 100644 docs/api/qiskit/1.0/transpiler_preset.mdx create mode 100644 docs/api/qiskit/1.0/transpiler_synthesis_plugins.mdx create mode 100644 docs/api/qiskit/1.0/utils.mdx create mode 100644 docs/api/qiskit/1.0/visualization.mdx create mode 100644 docs/api/qiskit/dev/qiskit.primitives.SamplerPubResult.mdx create mode 100644 docs/api/qiskit/qiskit.primitives.BackendEstimatorV2.mdx create mode 100644 docs/api/qiskit/qiskit.primitives.BackendSamplerV2.mdx create mode 100644 docs/api/qiskit/qiskit.primitives.SamplerPubResult.mdx create mode 100644 docs/api/qiskit/qiskit.primitives.Shaped.mdx create mode 100644 docs/api/qiskit/qiskit.transpiler.passes.ElidePermutations.mdx create mode 100644 docs/api/qiskit/qiskit.transpiler.passes.RemoveFinalReset.mdx create mode 100644 docs/api/qiskit/qiskit.transpiler.passes.StarPreRouting.mdx create mode 100644 docs/api/qiskit/release-notes/1.1.mdx create mode 100644 public/api/qiskit/1.0/objects.inv create mode 100644 public/images/api/qiskit/1.0/circuit-1.png create mode 100644 public/images/api/qiskit/1.0/circuit-2.png create mode 100644 public/images/api/qiskit/1.0/circuit-3.png create mode 100644 public/images/api/qiskit/1.0/circuit-4.png create mode 100644 public/images/api/qiskit/1.0/circuit-5.png create mode 100644 public/images/api/qiskit/1.0/circuit_library-1.png create mode 100644 public/images/api/qiskit/1.0/converters-1.png create mode 100644 public/images/api/qiskit/1.0/depth.gif create mode 100644 public/images/api/qiskit/1.0/mapping.png create mode 100644 public/images/api/qiskit/1.0/providers_fake_provider-1_00.png create mode 100644 public/images/api/qiskit/1.0/providers_fake_provider-1_01.png create mode 100644 public/images/api/qiskit/1.0/providers_fake_provider-1_02.png create mode 100644 public/images/api/qiskit/1.0/pulse-1.png create mode 100644 public/images/api/qiskit/1.0/pulse-2.png create mode 100644 public/images/api/qiskit/1.0/pulse-3.png create mode 100644 public/images/api/qiskit/1.0/pulse-4.png create mode 100644 public/images/api/qiskit/1.0/pulse-5.png create mode 100644 public/images/api/qiskit/1.0/pulse-6.png create mode 100644 public/images/api/qiskit/1.0/pulse-7.png create mode 100644 public/images/api/qiskit/1.0/qasm3-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-ControlledGate-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-ControlledGate-2.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-InstructionSet-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-Operation-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-Parameter-1_00.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-Parameter-1_01.png rename public/images/api/qiskit/{dev => 1.0}/qiskit-circuit-QuantumCircuit-1.png (100%) rename public/images/api/qiskit/{dev => 1.0}/qiskit-circuit-QuantumCircuit-2.png (100%) rename public/images/api/qiskit/{dev => 1.0}/qiskit-circuit-QuantumCircuit-3_00.png (100%) rename public/images/api/qiskit/{dev => 1.0}/qiskit-circuit-QuantumCircuit-3_01.png (100%) rename public/images/api/qiskit/{dev => 1.0}/qiskit-circuit-QuantumCircuit-4_00.png (100%) rename public/images/api/qiskit/{dev => 1.0}/qiskit-circuit-QuantumCircuit-4_01.png (100%) create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-QuantumCircuit-5.png rename public/images/api/qiskit/{dev => 1.0}/qiskit-circuit-QuantumCircuit-6.png (100%) create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-AND-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-AND-2.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-FourierChecking-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-GMS-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-GR-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-GRX-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-GRY-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-GRZ-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-GraphState-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-HiddenLinearFunction-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-IQP-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-IQP-2.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-InnerProduct-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-MCMTVChain-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-OR-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-OR-2.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-PauliTwoDesign-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-Permutation-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-Permutation-2.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-PermutationGate-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-PermutationGate-2.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-PhaseEstimation-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-PiecewiseChebyshev-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-QFT-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-QFT-2.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-QFT-3.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-QuantumVolume-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-QuantumVolume-2.png create mode 100644 public/images/api/qiskit/1.0/qiskit-circuit-library-XOR-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-primitives-StatevectorEstimator-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-pulse-library-SymbolicPulse-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-quantum_info-Statevector-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-transpiler-passes-DynamicalDecoupling-1_00.png create mode 100644 public/images/api/qiskit/1.0/qiskit-transpiler-passes-DynamicalDecoupling-1_01.png create mode 100644 public/images/api/qiskit/1.0/qiskit-transpiler-passes-FilterOpNodes-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-transpiler-passes-PadDynamicalDecoupling-1_00.png create mode 100644 public/images/api/qiskit/1.0/qiskit-transpiler-passes-PadDynamicalDecoupling-1_01.png create mode 100644 public/images/api/qiskit/1.0/qiskit-transpiler-passes-RemoveBarriers-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-circuit_drawer-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_bloch_multivector-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_bloch_multivector-2.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_bloch_vector-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_bloch_vector-2.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_circuit_layout-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_coupling_map-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_distribution-1_00.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_distribution-1_01.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_distribution-1_02.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_error_map-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_gate_map-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_histogram-1_00.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_histogram-1_01.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_histogram-1_02.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_state_city-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_state_city-2.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_state_hinton-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_state_paulivec-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_state_paulivec-2.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_state_qsphere-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-plot_state_qsphere-2.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-timeline_drawer-1.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-timeline_drawer-2.png create mode 100644 public/images/api/qiskit/1.0/qiskit-visualization-timeline_drawer-3.png create mode 100644 public/images/api/qiskit/1.0/transpiler-10.png create mode 100644 public/images/api/qiskit/1.0/transpiler-11.png create mode 100644 public/images/api/qiskit/1.0/transpiler-12.png create mode 100644 public/images/api/qiskit/1.0/transpiler-13.png create mode 100644 public/images/api/qiskit/1.0/transpiler-14.png create mode 100644 public/images/api/qiskit/1.0/transpiler-15.png create mode 100644 public/images/api/qiskit/1.0/transpiler-16.png create mode 100644 public/images/api/qiskit/1.0/transpiler-17.png create mode 100644 public/images/api/qiskit/1.0/transpiler-4.png create mode 100644 public/images/api/qiskit/1.0/transpiler-5.png create mode 100644 public/images/api/qiskit/1.0/transpiler-6.png create mode 100644 public/images/api/qiskit/1.0/transpiler-7.png create mode 100644 public/images/api/qiskit/1.0/transpiler-8.png create mode 100644 public/images/api/qiskit/1.0/transpiler-9.png create mode 100644 public/images/api/qiskit/1.0/transpiling_core_steps.png create mode 100644 public/images/api/qiskit/1.0/visualization-1.png create mode 100644 public/images/api/qiskit/1.0/visualization-2.png create mode 100644 public/images/api/qiskit/1.0/visualization-3.png create mode 100644 public/images/api/qiskit/1.0/visualization-4.png create mode 100644 public/images/api/qiskit/1.0/visualization-5.png create mode 100644 public/images/api/qiskit/1.0/visualization-6.png delete mode 100644 public/images/api/qiskit/dev/circuit-3.png rename public/images/api/qiskit/dev/{circuit-5.png => circuit-4.png} (99%) create mode 100644 public/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-1_00.png create mode 100644 public/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-1_01.png create mode 100644 public/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-2_00.png create mode 100644 public/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-2_01.png create mode 100644 public/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-3.png create mode 100644 public/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-4.png create mode 100644 public/images/api/qiskit/dev/release_notes-6.png create mode 100644 public/images/api/qiskit/qiskit-circuit-QuantumCircuit-1_00.png create mode 100644 public/images/api/qiskit/qiskit-circuit-QuantumCircuit-1_01.png create mode 100644 public/images/api/qiskit/qiskit-circuit-QuantumCircuit-2_00.png create mode 100644 public/images/api/qiskit/qiskit-circuit-QuantumCircuit-2_01.png create mode 100644 public/images/api/qiskit/qiskit-circuit-QuantumCircuit-3.png create mode 100644 public/images/api/qiskit/qiskit-circuit-QuantumCircuit-4.png create mode 100644 public/images/api/qiskit/qiskit-transpiler-passes-StarPreRouting-1.png create mode 100644 public/images/api/qiskit/release_notes-2.png create mode 100644 public/images/api/qiskit/release_notes-3.png create mode 100644 public/images/api/qiskit/release_notes-4.png create mode 100644 public/images/api/qiskit/release_notes-5.png create mode 100644 public/images/api/qiskit/release_notes-6.png create mode 100644 public/images/api/qiskit/release_notes-7.png diff --git a/docs/api/qiskit/0.19/_toc.json b/docs/api/qiskit/0.19/_toc.json index eccd01729b0..50d6290dec9 100644 --- a/docs/api/qiskit/0.19/_toc.json +++ b/docs/api/qiskit/0.19/_toc.json @@ -3840,6 +3840,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.24/_toc.json b/docs/api/qiskit/0.24/_toc.json index 03f7a23ac22..5583067b731 100644 --- a/docs/api/qiskit/0.24/_toc.json +++ b/docs/api/qiskit/0.24/_toc.json @@ -4864,6 +4864,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.25/_toc.json b/docs/api/qiskit/0.25/_toc.json index 39f93db3c3f..4559842cde3 100644 --- a/docs/api/qiskit/0.25/_toc.json +++ b/docs/api/qiskit/0.25/_toc.json @@ -5843,6 +5843,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.26/_toc.json b/docs/api/qiskit/0.26/_toc.json index d3ea8a8fd70..f9bbe8e917a 100644 --- a/docs/api/qiskit/0.26/_toc.json +++ b/docs/api/qiskit/0.26/_toc.json @@ -5888,6 +5888,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.27/_toc.json b/docs/api/qiskit/0.27/_toc.json index a05f645f6ce..9c7b13cbe4f 100644 --- a/docs/api/qiskit/0.27/_toc.json +++ b/docs/api/qiskit/0.27/_toc.json @@ -5888,6 +5888,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.28/_toc.json b/docs/api/qiskit/0.28/_toc.json index 95c7067b1c8..86747e4d631 100644 --- a/docs/api/qiskit/0.28/_toc.json +++ b/docs/api/qiskit/0.28/_toc.json @@ -5984,6 +5984,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.29/_toc.json b/docs/api/qiskit/0.29/_toc.json index 3a432d74d94..a139c4277dd 100644 --- a/docs/api/qiskit/0.29/_toc.json +++ b/docs/api/qiskit/0.29/_toc.json @@ -6009,6 +6009,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.30/_toc.json b/docs/api/qiskit/0.30/_toc.json index 4700088cb0e..51c2115961b 100644 --- a/docs/api/qiskit/0.30/_toc.json +++ b/docs/api/qiskit/0.30/_toc.json @@ -6022,6 +6022,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.31/_toc.json b/docs/api/qiskit/0.31/_toc.json index c9a0eb6fd9b..f559d2a59d6 100644 --- a/docs/api/qiskit/0.31/_toc.json +++ b/docs/api/qiskit/0.31/_toc.json @@ -6022,6 +6022,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.32/_toc.json b/docs/api/qiskit/0.32/_toc.json index 34f67547316..25ee2cf9b0d 100644 --- a/docs/api/qiskit/0.32/_toc.json +++ b/docs/api/qiskit/0.32/_toc.json @@ -6022,6 +6022,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.33/_toc.json b/docs/api/qiskit/0.33/_toc.json index ac7ebc96dc6..482d285c9d5 100644 --- a/docs/api/qiskit/0.33/_toc.json +++ b/docs/api/qiskit/0.33/_toc.json @@ -4362,6 +4362,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.35/_toc.json b/docs/api/qiskit/0.35/_toc.json index a523103d9be..61398e85912 100644 --- a/docs/api/qiskit/0.35/_toc.json +++ b/docs/api/qiskit/0.35/_toc.json @@ -4541,6 +4541,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.36/_toc.json b/docs/api/qiskit/0.36/_toc.json index bd6d8e5d274..b1663023311 100644 --- a/docs/api/qiskit/0.36/_toc.json +++ b/docs/api/qiskit/0.36/_toc.json @@ -4524,6 +4524,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.37/_toc.json b/docs/api/qiskit/0.37/_toc.json index 6684a9f46fd..6cead843750 100644 --- a/docs/api/qiskit/0.37/_toc.json +++ b/docs/api/qiskit/0.37/_toc.json @@ -4591,6 +4591,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.38/_toc.json b/docs/api/qiskit/0.38/_toc.json index a27a91fadae..e68d2dea4e7 100644 --- a/docs/api/qiskit/0.38/_toc.json +++ b/docs/api/qiskit/0.38/_toc.json @@ -4588,6 +4588,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.39/_toc.json b/docs/api/qiskit/0.39/_toc.json index 5d2b8934785..b71f1c976b9 100644 --- a/docs/api/qiskit/0.39/_toc.json +++ b/docs/api/qiskit/0.39/_toc.json @@ -4951,6 +4951,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.40/_toc.json b/docs/api/qiskit/0.40/_toc.json index 2ac3260646d..987e869de93 100644 --- a/docs/api/qiskit/0.40/_toc.json +++ b/docs/api/qiskit/0.40/_toc.json @@ -5155,6 +5155,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.41/_toc.json b/docs/api/qiskit/0.41/_toc.json index 5abd374dea0..9be796b4446 100644 --- a/docs/api/qiskit/0.41/_toc.json +++ b/docs/api/qiskit/0.41/_toc.json @@ -5163,6 +5163,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.42/_toc.json b/docs/api/qiskit/0.42/_toc.json index f83ace9cf65..f2e1b865275 100644 --- a/docs/api/qiskit/0.42/_toc.json +++ b/docs/api/qiskit/0.42/_toc.json @@ -5159,6 +5159,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.43/_toc.json b/docs/api/qiskit/0.43/_toc.json index 3155e8129b1..64221249fa4 100644 --- a/docs/api/qiskit/0.43/_toc.json +++ b/docs/api/qiskit/0.43/_toc.json @@ -4449,6 +4449,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.44/_toc.json b/docs/api/qiskit/0.44/_toc.json index 3ada161da5c..b87546e874c 100644 --- a/docs/api/qiskit/0.44/_toc.json +++ b/docs/api/qiskit/0.44/_toc.json @@ -3410,6 +3410,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.45/_toc.json b/docs/api/qiskit/0.45/_toc.json index 5a98b8f28ce..e0b587e9b22 100644 --- a/docs/api/qiskit/0.45/_toc.json +++ b/docs/api/qiskit/0.45/_toc.json @@ -3463,6 +3463,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/0.46/_toc.json b/docs/api/qiskit/0.46/_toc.json index aa7ce8e37d2..938d033b613 100644 --- a/docs/api/qiskit/0.46/_toc.json +++ b/docs/api/qiskit/0.46/_toc.json @@ -3492,6 +3492,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/1.0/_package.json b/docs/api/qiskit/1.0/_package.json new file mode 100644 index 00000000000..de9636b477d --- /dev/null +++ b/docs/api/qiskit/1.0/_package.json @@ -0,0 +1,4 @@ +{ + "name": "qiskit", + "version": "1.0.2" +} diff --git a/docs/api/qiskit/1.0/_toc.json b/docs/api/qiskit/1.0/_toc.json new file mode 100644 index 00000000000..336249e3d30 --- /dev/null +++ b/docs/api/qiskit/1.0/_toc.json @@ -0,0 +1,2392 @@ +{ + "title": "Qiskit SDK", + "children": [ + { + "title": "API index", + "url": "/api/qiskit/1.0" + }, + { + "title": "Circuit construction", + "children": [ + { + "title": "qiskit.circuit", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/circuit" + }, + { + "title": "AncillaQubit", + "url": "/api/qiskit/1.0/qiskit.circuit.AncillaQubit" + }, + { + "title": "AncillaRegister", + "url": "/api/qiskit/1.0/qiskit.circuit.AncillaRegister" + }, + { + "title": "AnnotatedOperation", + "url": "/api/qiskit/1.0/qiskit.circuit.AnnotatedOperation" + }, + { + "title": "Bit", + "url": "/api/qiskit/1.0/qiskit.circuit.Bit" + }, + { + "title": "BreakLoopOp", + "url": "/api/qiskit/1.0/qiskit.circuit.BreakLoopOp" + }, + { + "title": "CircuitInstruction", + "url": "/api/qiskit/1.0/qiskit.circuit.CircuitInstruction" + }, + { + "title": "ClassicalRegister", + "url": "/api/qiskit/1.0/qiskit.circuit.ClassicalRegister" + }, + { + "title": "Clbit", + "url": "/api/qiskit/1.0/qiskit.circuit.Clbit" + }, + { + "title": "CommutationChecker", + "url": "/api/qiskit/1.0/qiskit.circuit.CommutationChecker" + }, + { + "title": "ContinueLoopOp", + "url": "/api/qiskit/1.0/qiskit.circuit.ContinueLoopOp" + }, + { + "title": "ControlFlowOp", + "url": "/api/qiskit/1.0/qiskit.circuit.ControlFlowOp" + }, + { + "title": "ControlledGate", + "url": "/api/qiskit/1.0/qiskit.circuit.ControlledGate" + }, + { + "title": "ControlModifier", + "url": "/api/qiskit/1.0/qiskit.circuit.ControlModifier" + }, + { + "title": "Delay", + "url": "/api/qiskit/1.0/qiskit.circuit.Delay" + }, + { + "title": "EquivalenceLibrary", + "url": "/api/qiskit/1.0/qiskit.circuit.EquivalenceLibrary" + }, + { + "title": "ForLoopOp", + "url": "/api/qiskit/1.0/qiskit.circuit.ForLoopOp" + }, + { + "title": "Gate", + "url": "/api/qiskit/1.0/qiskit.circuit.Gate" + }, + { + "title": "IfElseOp", + "url": "/api/qiskit/1.0/qiskit.circuit.IfElseOp" + }, + { + "title": "Instruction", + "url": "/api/qiskit/1.0/qiskit.circuit.Instruction" + }, + { + "title": "InstructionSet", + "url": "/api/qiskit/1.0/qiskit.circuit.InstructionSet" + }, + { + "title": "InverseModifier", + "url": "/api/qiskit/1.0/qiskit.circuit.InverseModifier" + }, + { + "title": "Operation", + "url": "/api/qiskit/1.0/qiskit.circuit.Operation" + }, + { + "title": "Parameter", + "url": "/api/qiskit/1.0/qiskit.circuit.Parameter" + }, + { + "title": "ParameterExpression", + "url": "/api/qiskit/1.0/qiskit.circuit.ParameterExpression" + }, + { + "title": "ParameterVector", + "url": "/api/qiskit/1.0/qiskit.circuit.ParameterVector" + }, + { + "title": "PowerModifier", + "url": "/api/qiskit/1.0/qiskit.circuit.PowerModifier" + }, + { + "title": "QuantumCircuit", + "url": "/api/qiskit/1.0/qiskit.circuit.QuantumCircuit" + }, + { + "title": "QuantumRegister", + "url": "/api/qiskit/1.0/qiskit.circuit.QuantumRegister" + }, + { + "title": "Qubit", + "url": "/api/qiskit/1.0/qiskit.circuit.Qubit" + }, + { + "title": "Register", + "url": "/api/qiskit/1.0/qiskit.circuit.Register" + }, + { + "title": "SwitchCaseOp", + "url": "/api/qiskit/1.0/qiskit.circuit.SwitchCaseOp" + }, + { + "title": "WhileLoopOp", + "url": "/api/qiskit/1.0/qiskit.circuit.WhileLoopOp" + } + ] + }, + { + "title": "qiskit.circuit.classical", + "url": "/api/qiskit/1.0/circuit_classical" + }, + { + "title": "qiskit.circuit.classicalfunction", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/classicalfunction" + }, + { + "title": "BooleanExpression", + "url": "/api/qiskit/1.0/qiskit.circuit.classicalfunction.BooleanExpression" + }, + { + "title": "ClassicalFunction", + "url": "/api/qiskit/1.0/qiskit.circuit.classicalfunction.ClassicalFunction" + }, + { + "title": "ClassicalFunctionCompilerTypeError", + "url": "/api/qiskit/1.0/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError" + }, + { + "title": "ClassicalFunctionParseError", + "url": "/api/qiskit/1.0/qiskit.circuit.classicalfunction.ClassicalFunctionParseError" + } + ] + }, + { + "title": "qiskit.circuit.library", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/circuit_library" + }, + { + "title": "AND", + "url": "/api/qiskit/1.0/qiskit.circuit.library.AND" + }, + { + "title": "Barrier", + "url": "/api/qiskit/1.0/qiskit.circuit.library.Barrier" + }, + { + "title": "C3SXGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.C3SXGate" + }, + { + "title": "C3XGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.C3XGate" + }, + { + "title": "C4XGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.C4XGate" + }, + { + "title": "CCXGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CCXGate" + }, + { + "title": "CCZGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CCZGate" + }, + { + "title": "CDKMRippleCarryAdder", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CDKMRippleCarryAdder" + }, + { + "title": "CHGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CHGate" + }, + { + "title": "CPhaseGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CPhaseGate" + }, + { + "title": "CRXGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CRXGate" + }, + { + "title": "CRYGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CRYGate" + }, + { + "title": "CRZGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CRZGate" + }, + { + "title": "CSdgGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CSdgGate" + }, + { + "title": "CSGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CSGate" + }, + { + "title": "CSwapGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CSwapGate" + }, + { + "title": "CSXGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CSXGate" + }, + { + "title": "CU1Gate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CU1Gate" + }, + { + "title": "CU3Gate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CU3Gate" + }, + { + "title": "CUGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CUGate" + }, + { + "title": "CXGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CXGate" + }, + { + "title": "CYGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CYGate" + }, + { + "title": "CZGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.CZGate" + }, + { + "title": "DCXGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.DCXGate" + }, + { + "title": "Diagonal", + "url": "/api/qiskit/1.0/qiskit.circuit.library.Diagonal" + }, + { + "title": "DiagonalGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.DiagonalGate" + }, + { + "title": "DraperQFTAdder", + "url": "/api/qiskit/1.0/qiskit.circuit.library.DraperQFTAdder" + }, + { + "title": "ECRGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.ECRGate" + }, + { + "title": "EfficientSU2", + "url": "/api/qiskit/1.0/qiskit.circuit.library.EfficientSU2" + }, + { + "title": "EvolvedOperatorAnsatz", + "url": "/api/qiskit/1.0/qiskit.circuit.library.EvolvedOperatorAnsatz" + }, + { + "title": "ExactReciprocal", + "url": "/api/qiskit/1.0/qiskit.circuit.library.ExactReciprocal" + }, + { + "title": "ExcitationPreserving", + "url": "/api/qiskit/1.0/qiskit.circuit.library.ExcitationPreserving" + }, + { + "title": "FourierChecking", + "url": "/api/qiskit/1.0/qiskit.circuit.library.FourierChecking" + }, + { + "title": "FunctionalPauliRotations", + "url": "/api/qiskit/1.0/qiskit.circuit.library.FunctionalPauliRotations" + }, + { + "title": "GlobalPhaseGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.GlobalPhaseGate" + }, + { + "title": "GMS", + "url": "/api/qiskit/1.0/qiskit.circuit.library.GMS" + }, + { + "title": "GR", + "url": "/api/qiskit/1.0/qiskit.circuit.library.GR" + }, + { + "title": "GraphState", + "url": "/api/qiskit/1.0/qiskit.circuit.library.GraphState" + }, + { + "title": "GroverOperator", + "url": "/api/qiskit/1.0/qiskit.circuit.library.GroverOperator" + }, + { + "title": "GRX", + "url": "/api/qiskit/1.0/qiskit.circuit.library.GRX" + }, + { + "title": "GRY", + "url": "/api/qiskit/1.0/qiskit.circuit.library.GRY" + }, + { + "title": "GRZ", + "url": "/api/qiskit/1.0/qiskit.circuit.library.GRZ" + }, + { + "title": "HamiltonianGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.HamiltonianGate" + }, + { + "title": "HGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.HGate" + }, + { + "title": "HiddenLinearFunction", + "url": "/api/qiskit/1.0/qiskit.circuit.library.HiddenLinearFunction" + }, + { + "title": "HRSCumulativeMultiplier", + "url": "/api/qiskit/1.0/qiskit.circuit.library.HRSCumulativeMultiplier" + }, + { + "title": "IGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.IGate" + }, + { + "title": "Initialize", + "url": "/api/qiskit/1.0/qiskit.circuit.library.Initialize" + }, + { + "title": "InnerProduct", + "url": "/api/qiskit/1.0/qiskit.circuit.library.InnerProduct" + }, + { + "title": "IntegerComparator", + "url": "/api/qiskit/1.0/qiskit.circuit.library.IntegerComparator" + }, + { + "title": "IQP", + "url": "/api/qiskit/1.0/qiskit.circuit.library.IQP" + }, + { + "title": "Isometry", + "url": "/api/qiskit/1.0/qiskit.circuit.library.Isometry" + }, + { + "title": "iSwapGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.iSwapGate" + }, + { + "title": "LinearAmplitudeFunction", + "url": "/api/qiskit/1.0/qiskit.circuit.library.LinearAmplitudeFunction" + }, + { + "title": "LinearFunction", + "url": "/api/qiskit/1.0/qiskit.circuit.library.LinearFunction" + }, + { + "title": "LinearPauliRotations", + "url": "/api/qiskit/1.0/qiskit.circuit.library.LinearPauliRotations" + }, + { + "title": "MCMT", + "url": "/api/qiskit/1.0/qiskit.circuit.library.MCMT" + }, + { + "title": "MCMTVChain", + "url": "/api/qiskit/1.0/qiskit.circuit.library.MCMTVChain" + }, + { + "title": "MCPhaseGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.MCPhaseGate" + }, + { + "title": "MCXGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.MCXGate" + }, + { + "title": "MCXGrayCode", + "url": "/api/qiskit/1.0/qiskit.circuit.library.MCXGrayCode" + }, + { + "title": "MCXRecursive", + "url": "/api/qiskit/1.0/qiskit.circuit.library.MCXRecursive" + }, + { + "title": "MCXVChain", + "url": "/api/qiskit/1.0/qiskit.circuit.library.MCXVChain" + }, + { + "title": "Measure", + "url": "/api/qiskit/1.0/qiskit.circuit.library.Measure" + }, + { + "title": "MSGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.MSGate" + }, + { + "title": "NLocal", + "url": "/api/qiskit/1.0/qiskit.circuit.library.NLocal" + }, + { + "title": "OR", + "url": "/api/qiskit/1.0/qiskit.circuit.library.OR" + }, + { + "title": "PauliEvolutionGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.PauliEvolutionGate" + }, + { + "title": "PauliFeatureMap", + "url": "/api/qiskit/1.0/qiskit.circuit.library.PauliFeatureMap" + }, + { + "title": "PauliGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.PauliGate" + }, + { + "title": "PauliTwoDesign", + "url": "/api/qiskit/1.0/qiskit.circuit.library.PauliTwoDesign" + }, + { + "title": "Permutation", + "url": "/api/qiskit/1.0/qiskit.circuit.library.Permutation" + }, + { + "title": "PermutationGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.PermutationGate" + }, + { + "title": "PhaseEstimation", + "url": "/api/qiskit/1.0/qiskit.circuit.library.PhaseEstimation" + }, + { + "title": "PhaseGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.PhaseGate" + }, + { + "title": "PhaseOracle", + "url": "/api/qiskit/1.0/qiskit.circuit.library.PhaseOracle" + }, + { + "title": "PiecewiseChebyshev", + "url": "/api/qiskit/1.0/qiskit.circuit.library.PiecewiseChebyshev" + }, + { + "title": "PiecewiseLinearPauliRotations", + "url": "/api/qiskit/1.0/qiskit.circuit.library.PiecewiseLinearPauliRotations" + }, + { + "title": "PiecewisePolynomialPauliRotations", + "url": "/api/qiskit/1.0/qiskit.circuit.library.PiecewisePolynomialPauliRotations" + }, + { + "title": "PolynomialPauliRotations", + "url": "/api/qiskit/1.0/qiskit.circuit.library.PolynomialPauliRotations" + }, + { + "title": "QAOAAnsatz", + "url": "/api/qiskit/1.0/qiskit.circuit.library.QAOAAnsatz" + }, + { + "title": "QFT", + "url": "/api/qiskit/1.0/qiskit.circuit.library.QFT" + }, + { + "title": "QuadraticForm", + "url": "/api/qiskit/1.0/qiskit.circuit.library.QuadraticForm" + }, + { + "title": "QuantumVolume", + "url": "/api/qiskit/1.0/qiskit.circuit.library.QuantumVolume" + }, + { + "title": "RC3XGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.RC3XGate" + }, + { + "title": "RCCXGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.RCCXGate" + }, + { + "title": "RealAmplitudes", + "url": "/api/qiskit/1.0/qiskit.circuit.library.RealAmplitudes" + }, + { + "title": "Reset", + "url": "/api/qiskit/1.0/qiskit.circuit.library.Reset" + }, + { + "title": "RGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.RGate" + }, + { + "title": "RGQFTMultiplier", + "url": "/api/qiskit/1.0/qiskit.circuit.library.RGQFTMultiplier" + }, + { + "title": "RVGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.RVGate" + }, + { + "title": "RXGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.RXGate" + }, + { + "title": "RXXGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.RXXGate" + }, + { + "title": "RYGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.RYGate" + }, + { + "title": "RYYGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.RYYGate" + }, + { + "title": "RZGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.RZGate" + }, + { + "title": "RZXGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.RZXGate" + }, + { + "title": "RZZGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.RZZGate" + }, + { + "title": "SdgGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.SdgGate" + }, + { + "title": "SGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.SGate" + }, + { + "title": "StatePreparation", + "url": "/api/qiskit/1.0/qiskit.circuit.library.StatePreparation" + }, + { + "title": "SwapGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.SwapGate" + }, + { + "title": "SXdgGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.SXdgGate" + }, + { + "title": "SXGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.SXGate" + }, + { + "title": "TdgGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.TdgGate" + }, + { + "title": "TGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.TGate" + }, + { + "title": "TwoLocal", + "url": "/api/qiskit/1.0/qiskit.circuit.library.TwoLocal" + }, + { + "title": "U1Gate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.U1Gate" + }, + { + "title": "U2Gate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.U2Gate" + }, + { + "title": "U3Gate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.U3Gate" + }, + { + "title": "UCGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.UCGate" + }, + { + "title": "UCPauliRotGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.UCPauliRotGate" + }, + { + "title": "UCRXGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.UCRXGate" + }, + { + "title": "UCRYGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.UCRYGate" + }, + { + "title": "UCRZGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.UCRZGate" + }, + { + "title": "UGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.UGate" + }, + { + "title": "UnitaryGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.UnitaryGate" + }, + { + "title": "UnitaryOverlap", + "url": "/api/qiskit/1.0/qiskit.circuit.library.UnitaryOverlap" + }, + { + "title": "VBERippleCarryAdder", + "url": "/api/qiskit/1.0/qiskit.circuit.library.VBERippleCarryAdder" + }, + { + "title": "WeightedAdder", + "url": "/api/qiskit/1.0/qiskit.circuit.library.WeightedAdder" + }, + { + "title": "XGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.XGate" + }, + { + "title": "XOR", + "url": "/api/qiskit/1.0/qiskit.circuit.library.XOR" + }, + { + "title": "XXMinusYYGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.XXMinusYYGate" + }, + { + "title": "XXPlusYYGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.XXPlusYYGate" + }, + { + "title": "YGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.YGate" + }, + { + "title": "ZFeatureMap", + "url": "/api/qiskit/1.0/qiskit.circuit.library.ZFeatureMap" + }, + { + "title": "ZGate", + "url": "/api/qiskit/1.0/qiskit.circuit.library.ZGate" + }, + { + "title": "ZZFeatureMap", + "url": "/api/qiskit/1.0/qiskit.circuit.library.ZZFeatureMap" + } + ] + }, + { + "title": "qiskit.circuit.singleton", + "url": "/api/qiskit/1.0/circuit_singleton" + } + ] + }, + { + "title": "Quantum information (qiskit.quantum_info)", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/quantum_info" + }, + { + "title": "Chi", + "url": "/api/qiskit/1.0/qiskit.quantum_info.Chi" + }, + { + "title": "Choi", + "url": "/api/qiskit/1.0/qiskit.quantum_info.Choi" + }, + { + "title": "Clifford", + "url": "/api/qiskit/1.0/qiskit.quantum_info.Clifford" + }, + { + "title": "CNOTDihedral", + "url": "/api/qiskit/1.0/qiskit.quantum_info.CNOTDihedral" + }, + { + "title": "DensityMatrix", + "url": "/api/qiskit/1.0/qiskit.quantum_info.DensityMatrix" + }, + { + "title": "Kraus", + "url": "/api/qiskit/1.0/qiskit.quantum_info.Kraus" + }, + { + "title": "Operator", + "url": "/api/qiskit/1.0/qiskit.quantum_info.Operator" + }, + { + "title": "Pauli", + "url": "/api/qiskit/1.0/qiskit.quantum_info.Pauli" + }, + { + "title": "pauli_basis", + "url": "/api/qiskit/1.0/qiskit.quantum_info.pauli_basis" + }, + { + "title": "PauliList", + "url": "/api/qiskit/1.0/qiskit.quantum_info.PauliList" + }, + { + "title": "PTM", + "url": "/api/qiskit/1.0/qiskit.quantum_info.PTM" + }, + { + "title": "Quaternion", + "url": "/api/qiskit/1.0/qiskit.quantum_info.Quaternion" + }, + { + "title": "ScalarOp", + "url": "/api/qiskit/1.0/qiskit.quantum_info.ScalarOp" + }, + { + "title": "SparsePauliOp", + "url": "/api/qiskit/1.0/qiskit.quantum_info.SparsePauliOp" + }, + { + "title": "StabilizerState", + "url": "/api/qiskit/1.0/qiskit.quantum_info.StabilizerState" + }, + { + "title": "Statevector", + "url": "/api/qiskit/1.0/qiskit.quantum_info.Statevector" + }, + { + "title": "Stinespring", + "url": "/api/qiskit/1.0/qiskit.quantum_info.Stinespring" + }, + { + "title": "SuperOp", + "url": "/api/qiskit/1.0/qiskit.quantum_info.SuperOp" + }, + { + "title": "Z2Symmetries", + "url": "/api/qiskit/1.0/qiskit.quantum_info.Z2Symmetries" + } + ] + }, + { + "title": "Transpilation", + "children": [ + { + "title": "qiskit.converters", + "url": "/api/qiskit/1.0/converters" + }, + { + "title": "qiskit.dagcircuit", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/dagcircuit" + }, + { + "title": "DAGCircuit", + "url": "/api/qiskit/1.0/qiskit.dagcircuit.DAGCircuit" + }, + { + "title": "DAGDependency", + "url": "/api/qiskit/1.0/qiskit.dagcircuit.DAGDependency" + }, + { + "title": "DAGDepNode", + "url": "/api/qiskit/1.0/qiskit.dagcircuit.DAGDepNode" + }, + { + "title": "DAGInNode", + "url": "/api/qiskit/1.0/qiskit.dagcircuit.DAGInNode" + }, + { + "title": "DAGNode", + "url": "/api/qiskit/1.0/qiskit.dagcircuit.DAGNode" + }, + { + "title": "DAGOpNode", + "url": "/api/qiskit/1.0/qiskit.dagcircuit.DAGOpNode" + }, + { + "title": "DAGOutNode", + "url": "/api/qiskit/1.0/qiskit.dagcircuit.DAGOutNode" + } + ] + }, + { + "title": "qiskit.passmanager", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/passmanager" + }, + { + "title": "BaseController", + "url": "/api/qiskit/1.0/qiskit.passmanager.BaseController" + }, + { + "title": "BasePassManager", + "url": "/api/qiskit/1.0/qiskit.passmanager.BasePassManager" + }, + { + "title": "ConditionalController", + "url": "/api/qiskit/1.0/qiskit.passmanager.ConditionalController" + }, + { + "title": "DoWhileController", + "url": "/api/qiskit/1.0/qiskit.passmanager.DoWhileController" + }, + { + "title": "FlowControllerLinear", + "url": "/api/qiskit/1.0/qiskit.passmanager.FlowControllerLinear" + }, + { + "title": "GenericPass", + "url": "/api/qiskit/1.0/qiskit.passmanager.GenericPass" + }, + { + "title": "PassManagerState", + "url": "/api/qiskit/1.0/qiskit.passmanager.PassManagerState" + }, + { + "title": "PropertySet", + "url": "/api/qiskit/1.0/qiskit.passmanager.PropertySet" + }, + { + "title": "WorkflowStatus", + "url": "/api/qiskit/1.0/qiskit.passmanager.WorkflowStatus" + } + ] + }, + { + "title": "qiskit.synthesis", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/synthesis" + }, + { + "title": "EvolutionSynthesis", + "url": "/api/qiskit/1.0/qiskit.synthesis.EvolutionSynthesis" + }, + { + "title": "LieTrotter", + "url": "/api/qiskit/1.0/qiskit.synthesis.LieTrotter" + }, + { + "title": "MatrixExponential", + "url": "/api/qiskit/1.0/qiskit.synthesis.MatrixExponential" + }, + { + "title": "OneQubitEulerDecomposer", + "url": "/api/qiskit/1.0/qiskit.synthesis.OneQubitEulerDecomposer" + }, + { + "title": "ProductFormula", + "url": "/api/qiskit/1.0/qiskit.synthesis.ProductFormula" + }, + { + "title": "QDrift", + "url": "/api/qiskit/1.0/qiskit.synthesis.QDrift" + }, + { + "title": "SolovayKitaevDecomposition", + "url": "/api/qiskit/1.0/qiskit.synthesis.SolovayKitaevDecomposition" + }, + { + "title": "SuzukiTrotter", + "url": "/api/qiskit/1.0/qiskit.synthesis.SuzukiTrotter" + }, + { + "title": "TwoQubitBasisDecomposer", + "url": "/api/qiskit/1.0/qiskit.synthesis.TwoQubitBasisDecomposer" + }, + { + "title": "TwoQubitWeylDecomposition", + "url": "/api/qiskit/1.0/qiskit.synthesis.TwoQubitWeylDecomposition" + }, + { + "title": "XXDecomposer", + "url": "/api/qiskit/1.0/qiskit.synthesis.XXDecomposer" + } + ] + }, + { + "title": "qiskit.synthesis.unitary.aqc", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/qiskit.synthesis.unitary.aqc" + }, + { + "title": "ApproximateCircuit", + "url": "/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.ApproximateCircuit" + }, + { + "title": "ApproximatingObjective", + "url": "/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.ApproximatingObjective" + }, + { + "title": "AQC", + "url": "/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.AQC" + }, + { + "title": "CNOTUnitCircuit", + "url": "/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit" + }, + { + "title": "CNOTUnitObjective", + "url": "/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.CNOTUnitObjective" + }, + { + "title": "DefaultCNOTUnitObjective", + "url": "/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective" + }, + { + "title": "FastCNOTUnitObjective", + "url": "/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective" + } + ] + }, + { + "title": "qiskit.transpiler", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/transpiler" + }, + { + "title": "AnalysisPass", + "url": "/api/qiskit/1.0/qiskit.transpiler.AnalysisPass" + }, + { + "title": "CouplingMap", + "url": "/api/qiskit/1.0/qiskit.transpiler.CouplingMap" + }, + { + "title": "InstructionDurations", + "url": "/api/qiskit/1.0/qiskit.transpiler.InstructionDurations" + }, + { + "title": "InstructionProperties", + "url": "/api/qiskit/1.0/qiskit.transpiler.InstructionProperties" + }, + { + "title": "Layout", + "url": "/api/qiskit/1.0/qiskit.transpiler.Layout" + }, + { + "title": "PassManager", + "url": "/api/qiskit/1.0/qiskit.transpiler.PassManager" + }, + { + "title": "PassManagerConfig", + "url": "/api/qiskit/1.0/qiskit.transpiler.PassManagerConfig" + }, + { + "title": "StagedPassManager", + "url": "/api/qiskit/1.0/qiskit.transpiler.StagedPassManager" + }, + { + "title": "Target", + "url": "/api/qiskit/1.0/qiskit.transpiler.Target" + }, + { + "title": "TransformationPass", + "url": "/api/qiskit/1.0/qiskit.transpiler.TransformationPass" + }, + { + "title": "TranspileLayout", + "url": "/api/qiskit/1.0/qiskit.transpiler.TranspileLayout" + } + ] + }, + { + "title": "qiskit.transpiler.passes", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/transpiler_passes" + }, + { + "title": "ACGSynthesisPermutation", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation" + }, + { + "title": "AGSynthesisClifford", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford" + }, + { + "title": "ALAPSchedule", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.ALAPSchedule" + }, + { + "title": "ALAPScheduleAnalysis", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.ALAPScheduleAnalysis" + }, + { + "title": "AlignMeasures", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.AlignMeasures" + }, + { + "title": "ApplyLayout", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.ApplyLayout" + }, + { + "title": "AQCSynthesisPlugin", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin" + }, + { + "title": "ASAPSchedule", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.ASAPSchedule" + }, + { + "title": "ASAPScheduleAnalysis", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.ASAPScheduleAnalysis" + }, + { + "title": "BarrierBeforeFinalMeasurements", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements" + }, + { + "title": "BasicSwap", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.BasicSwap" + }, + { + "title": "BasicSynthesisPermutation", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation" + }, + { + "title": "BasisTranslator", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.BasisTranslator" + }, + { + "title": "BMSynthesisClifford", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford" + }, + { + "title": "CheckGateDirection", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.CheckGateDirection" + }, + { + "title": "CheckMap", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.CheckMap" + }, + { + "title": "Collect1qRuns", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.Collect1qRuns" + }, + { + "title": "Collect2qBlocks", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.Collect2qBlocks" + }, + { + "title": "CollectCliffords", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.CollectCliffords" + }, + { + "title": "CollectLinearFunctions", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.CollectLinearFunctions" + }, + { + "title": "CollectMultiQBlocks", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.CollectMultiQBlocks" + }, + { + "title": "CommutationAnalysis", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.CommutationAnalysis" + }, + { + "title": "CommutativeCancellation", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.CommutativeCancellation" + }, + { + "title": "CommutativeInverseCancellation", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.CommutativeInverseCancellation" + }, + { + "title": "Commuting2qGateRouter", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.Commuting2qGateRouter" + }, + { + "title": "ConsolidateBlocks", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.ConsolidateBlocks" + }, + { + "title": "ConstrainedReschedule", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.ConstrainedReschedule" + }, + { + "title": "ContainsInstruction", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.ContainsInstruction" + }, + { + "title": "ConvertConditionsToIfOps", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.ConvertConditionsToIfOps" + }, + { + "title": "CountOps", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.CountOps" + }, + { + "title": "CountOpsLongestPath", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.CountOpsLongestPath" + }, + { + "title": "CSPLayout", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.CSPLayout" + }, + { + "title": "CXCancellation", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.CXCancellation" + }, + { + "title": "DAGFixedPoint", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.DAGFixedPoint" + }, + { + "title": "DAGLongestPath", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.DAGLongestPath" + }, + { + "title": "Decompose", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.Decompose" + }, + { + "title": "DefaultSynthesisClifford", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford" + }, + { + "title": "DefaultSynthesisLinearFunction", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction" + }, + { + "title": "DefaultUnitarySynthesis", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis" + }, + { + "title": "DenseLayout", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.DenseLayout" + }, + { + "title": "Depth", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.Depth" + }, + { + "title": "DynamicalDecoupling", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.DynamicalDecoupling" + }, + { + "title": "EchoRZXWeylDecomposition", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.EchoRZXWeylDecomposition" + }, + { + "title": "EnlargeWithAncilla", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.EnlargeWithAncilla" + }, + { + "title": "FilterOpNodes", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.FilterOpNodes" + }, + { + "title": "FixedPoint", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.FixedPoint" + }, + { + "title": "FullAncillaAllocation", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.FullAncillaAllocation" + }, + { + "title": "GateDirection", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.GateDirection" + }, + { + "title": "GatesInBasis", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.GatesInBasis" + }, + { + "title": "GreedySynthesisClifford", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford" + }, + { + "title": "HighLevelSynthesis", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.HighLevelSynthesis" + }, + { + "title": "HLSConfig", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.HLSConfig" + }, + { + "title": "HoareOptimizer", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.HoareOptimizer" + }, + { + "title": "InstructionDurationCheck", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.InstructionDurationCheck" + }, + { + "title": "InverseCancellation", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.InverseCancellation" + }, + { + "title": "KMSSynthesisLinearFunction", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction" + }, + { + "title": "KMSSynthesisPermutation", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation" + }, + { + "title": "LayerLnnSynthesisClifford", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford" + }, + { + "title": "LayerSynthesisClifford", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford" + }, + { + "title": "Layout2qDistance", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.Layout2qDistance" + }, + { + "title": "LinearFunctionsToPermutations", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.LinearFunctionsToPermutations" + }, + { + "title": "LookaheadSwap", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.LookaheadSwap" + }, + { + "title": "MergeAdjacentBarriers", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.MergeAdjacentBarriers" + }, + { + "title": "MinimumPoint", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.MinimumPoint" + }, + { + "title": "NormalizeRXAngle", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.NormalizeRXAngle" + }, + { + "title": "NumTensorFactors", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.NumTensorFactors" + }, + { + "title": "Optimize1qGates", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.Optimize1qGates" + }, + { + "title": "Optimize1qGatesDecomposition", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.Optimize1qGatesDecomposition" + }, + { + "title": "Optimize1qGatesSimpleCommutation", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation" + }, + { + "title": "OptimizeAnnotated", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.OptimizeAnnotated" + }, + { + "title": "OptimizeCliffords", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.OptimizeCliffords" + }, + { + "title": "PadDelay", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.PadDelay" + }, + { + "title": "PadDynamicalDecoupling", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.PadDynamicalDecoupling" + }, + { + "title": "PMHSynthesisLinearFunction", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction" + }, + { + "title": "PulseGates", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.PulseGates" + }, + { + "title": "RemoveBarriers", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.RemoveBarriers" + }, + { + "title": "RemoveDiagonalGatesBeforeMeasure", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure" + }, + { + "title": "RemoveFinalMeasurements", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.RemoveFinalMeasurements" + }, + { + "title": "RemoveResetInZeroState", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.RemoveResetInZeroState" + }, + { + "title": "ResetAfterMeasureSimplification", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.ResetAfterMeasureSimplification" + }, + { + "title": "RXCalibrationBuilder", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.RXCalibrationBuilder" + }, + { + "title": "RZXCalibrationBuilder", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.RZXCalibrationBuilder" + }, + { + "title": "RZXCalibrationBuilderNoEcho", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho" + }, + { + "title": "SabreLayout", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.SabreLayout" + }, + { + "title": "SabrePreLayout", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.SabrePreLayout" + }, + { + "title": "SabreSwap", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.SabreSwap" + }, + { + "title": "SetIOLatency", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.SetIOLatency" + }, + { + "title": "SetLayout", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.SetLayout" + }, + { + "title": "Size", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.Size" + }, + { + "title": "SolovayKitaev", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.SolovayKitaev" + }, + { + "title": "SolovayKitaevSynthesis", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis" + }, + { + "title": "StochasticSwap", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.StochasticSwap" + }, + { + "title": "TemplateOptimization", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.TemplateOptimization" + }, + { + "title": "TimeUnitConversion", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.TimeUnitConversion" + }, + { + "title": "TokenSwapperSynthesisPermutation", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation" + }, + { + "title": "TranslateParameterizedGates", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.TranslateParameterizedGates" + }, + { + "title": "TrivialLayout", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.TrivialLayout" + }, + { + "title": "UnitarySynthesis", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.UnitarySynthesis" + }, + { + "title": "Unroll3qOrMore", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.Unroll3qOrMore" + }, + { + "title": "UnrollCustomDefinitions", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.UnrollCustomDefinitions" + }, + { + "title": "UnrollForLoops", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.UnrollForLoops" + }, + { + "title": "ValidatePulseGates", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.ValidatePulseGates" + }, + { + "title": "VF2Layout", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.VF2Layout" + }, + { + "title": "VF2PostLayout", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.VF2PostLayout" + }, + { + "title": "Width", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.Width" + } + ] + }, + { + "title": "qiskit.transpiler.passes.synthesis.plugin", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/transpiler_synthesis_plugins" + }, + { + "title": "high_level_synthesis_plugin_names", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names" + }, + { + "title": "HighLevelSynthesisPlugin", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin" + }, + { + "title": "HighLevelSynthesisPluginManager", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager" + }, + { + "title": "unitary_synthesis_plugin_names", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names" + }, + { + "title": "UnitarySynthesisPlugin", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin" + }, + { + "title": "UnitarySynthesisPluginManager", + "url": "/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager" + } + ] + }, + { + "title": "qiskit.transpiler.preset_passmanagers", + "url": "/api/qiskit/1.0/transpiler_preset" + }, + { + "title": "qiskit.transpiler.preset_passmanagers.plugin", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/transpiler_plugins" + }, + { + "title": "PassManagerStagePlugin", + "url": "/api/qiskit/1.0/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin" + }, + { + "title": "PassManagerStagePluginManager", + "url": "/api/qiskit/1.0/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager" + } + ] + } + ] + }, + { + "title": "Primitives and providers", + "children": [ + { + "title": "qiskit.primitives", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/primitives" + }, + { + "title": "BackendEstimator", + "url": "/api/qiskit/1.0/qiskit.primitives.BackendEstimator" + }, + { + "title": "BackendSampler", + "url": "/api/qiskit/1.0/qiskit.primitives.BackendSampler" + }, + { + "title": "BaseEstimatorV1", + "url": "/api/qiskit/1.0/qiskit.primitives.BaseEstimatorV1" + }, + { + "title": "BaseEstimatorV2", + "url": "/api/qiskit/1.0/qiskit.primitives.BaseEstimatorV2" + }, + { + "title": "BasePrimitiveJob", + "url": "/api/qiskit/1.0/qiskit.primitives.BasePrimitiveJob" + }, + { + "title": "BaseSamplerV1", + "url": "/api/qiskit/1.0/qiskit.primitives.BaseSamplerV1" + }, + { + "title": "BaseSamplerV2", + "url": "/api/qiskit/1.0/qiskit.primitives.BaseSamplerV2" + }, + { + "title": "BitArray", + "url": "/api/qiskit/1.0/qiskit.primitives.BitArray" + }, + { + "title": "DataBin", + "url": "/api/qiskit/1.0/qiskit.primitives.DataBin" + }, + { + "title": "Estimator", + "url": "/api/qiskit/1.0/qiskit.primitives.Estimator" + }, + { + "title": "EstimatorResult", + "url": "/api/qiskit/1.0/qiskit.primitives.EstimatorResult" + }, + { + "title": "PrimitiveJob", + "url": "/api/qiskit/1.0/qiskit.primitives.PrimitiveJob" + }, + { + "title": "PrimitiveResult", + "url": "/api/qiskit/1.0/qiskit.primitives.PrimitiveResult" + }, + { + "title": "PubResult", + "url": "/api/qiskit/1.0/qiskit.primitives.PubResult" + }, + { + "title": "Sampler", + "url": "/api/qiskit/1.0/qiskit.primitives.Sampler" + }, + { + "title": "SamplerResult", + "url": "/api/qiskit/1.0/qiskit.primitives.SamplerResult" + }, + { + "title": "StatevectorEstimator", + "url": "/api/qiskit/1.0/qiskit.primitives.StatevectorEstimator" + }, + { + "title": "StatevectorSampler", + "url": "/api/qiskit/1.0/qiskit.primitives.StatevectorSampler" + } + ] + }, + { + "title": "qiskit.providers", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/providers" + }, + { + "title": "Backend", + "url": "/api/qiskit/1.0/qiskit.providers.Backend" + }, + { + "title": "BackendV1", + "url": "/api/qiskit/1.0/qiskit.providers.BackendV1" + }, + { + "title": "BackendV2", + "url": "/api/qiskit/1.0/qiskit.providers.BackendV2" + }, + { + "title": "BackendV2Converter", + "url": "/api/qiskit/1.0/qiskit.providers.BackendV2Converter" + }, + { + "title": "convert_to_target", + "url": "/api/qiskit/1.0/qiskit.providers.convert_to_target" + }, + { + "title": "Job", + "url": "/api/qiskit/1.0/qiskit.providers.Job" + }, + { + "title": "JobStatus", + "url": "/api/qiskit/1.0/qiskit.providers.JobStatus" + }, + { + "title": "JobV1", + "url": "/api/qiskit/1.0/qiskit.providers.JobV1" + }, + { + "title": "Options", + "url": "/api/qiskit/1.0/qiskit.providers.Options" + }, + { + "title": "Provider", + "url": "/api/qiskit/1.0/qiskit.providers.Provider" + }, + { + "title": "ProviderV1", + "url": "/api/qiskit/1.0/qiskit.providers.ProviderV1" + }, + { + "title": "QubitProperties", + "url": "/api/qiskit/1.0/qiskit.providers.QubitProperties" + } + ] + }, + { + "title": "qiskit.providers.basic_provider", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/providers_basic_provider" + }, + { + "title": "BasicProvider", + "url": "/api/qiskit/1.0/qiskit.providers.basic_provider.BasicProvider" + }, + { + "title": "BasicProviderError", + "url": "/api/qiskit/1.0/qiskit.providers.basic_provider.BasicProviderError" + }, + { + "title": "BasicProviderJob", + "url": "/api/qiskit/1.0/qiskit.providers.basic_provider.BasicProviderJob" + }, + { + "title": "BasicSimulator", + "url": "/api/qiskit/1.0/qiskit.providers.basic_provider.BasicSimulator" + } + ] + }, + { + "title": "qiskit.providers.fake_provider", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/providers_fake_provider" + }, + { + "title": "Fake127QPulseV1", + "url": "/api/qiskit/1.0/qiskit.providers.fake_provider.Fake127QPulseV1" + }, + { + "title": "Fake1Q", + "url": "/api/qiskit/1.0/qiskit.providers.fake_provider.Fake1Q" + }, + { + "title": "Fake20QV1", + "url": "/api/qiskit/1.0/qiskit.providers.fake_provider.Fake20QV1" + }, + { + "title": "Fake27QPulseV1", + "url": "/api/qiskit/1.0/qiskit.providers.fake_provider.Fake27QPulseV1" + }, + { + "title": "Fake5QV1", + "url": "/api/qiskit/1.0/qiskit.providers.fake_provider.Fake5QV1" + }, + { + "title": "Fake7QPulseV1", + "url": "/api/qiskit/1.0/qiskit.providers.fake_provider.Fake7QPulseV1" + }, + { + "title": "FakeOpenPulse2Q", + "url": "/api/qiskit/1.0/qiskit.providers.fake_provider.FakeOpenPulse2Q" + }, + { + "title": "FakeOpenPulse3Q", + "url": "/api/qiskit/1.0/qiskit.providers.fake_provider.FakeOpenPulse3Q" + }, + { + "title": "GenericBackendV2", + "url": "/api/qiskit/1.0/qiskit.providers.fake_provider.GenericBackendV2" + } + ] + }, + { + "title": "qiskit.providers.models", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/providers_models" + }, + { + "title": "BackendConfiguration", + "url": "/api/qiskit/1.0/qiskit.providers.models.BackendConfiguration" + }, + { + "title": "BackendProperties", + "url": "/api/qiskit/1.0/qiskit.providers.models.BackendProperties" + }, + { + "title": "BackendStatus", + "url": "/api/qiskit/1.0/qiskit.providers.models.BackendStatus" + }, + { + "title": "Command", + "url": "/api/qiskit/1.0/qiskit.providers.models.Command" + }, + { + "title": "GateConfig", + "url": "/api/qiskit/1.0/qiskit.providers.models.GateConfig" + }, + { + "title": "GateProperties", + "url": "/api/qiskit/1.0/qiskit.providers.models.GateProperties" + }, + { + "title": "JobStatus", + "url": "/api/qiskit/1.0/qiskit.providers.models.JobStatus" + }, + { + "title": "Nduv", + "url": "/api/qiskit/1.0/qiskit.providers.models.Nduv" + }, + { + "title": "PulseBackendConfiguration", + "url": "/api/qiskit/1.0/qiskit.providers.models.PulseBackendConfiguration" + }, + { + "title": "PulseDefaults", + "url": "/api/qiskit/1.0/qiskit.providers.models.PulseDefaults" + }, + { + "title": "QasmBackendConfiguration", + "url": "/api/qiskit/1.0/qiskit.providers.models.QasmBackendConfiguration" + }, + { + "title": "UchannelLO", + "url": "/api/qiskit/1.0/qiskit.providers.models.UchannelLO" + } + ] + } + ] + }, + { + "title": "Results and visualizations", + "children": [ + { + "title": "qiskit.result", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/result" + }, + { + "title": "BaseReadoutMitigator", + "url": "/api/qiskit/1.0/qiskit.result.BaseReadoutMitigator" + }, + { + "title": "CorrelatedReadoutMitigator", + "url": "/api/qiskit/1.0/qiskit.result.CorrelatedReadoutMitigator" + }, + { + "title": "Counts", + "url": "/api/qiskit/1.0/qiskit.result.Counts" + }, + { + "title": "LocalReadoutMitigator", + "url": "/api/qiskit/1.0/qiskit.result.LocalReadoutMitigator" + }, + { + "title": "ProbDistribution", + "url": "/api/qiskit/1.0/qiskit.result.ProbDistribution" + }, + { + "title": "QuasiDistribution", + "url": "/api/qiskit/1.0/qiskit.result.QuasiDistribution" + }, + { + "title": "Result", + "url": "/api/qiskit/1.0/qiskit.result.Result" + }, + { + "title": "ResultError", + "url": "/api/qiskit/1.0/qiskit.result.ResultError" + } + ] + }, + { + "title": "qiskit.visualization", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/visualization" + }, + { + "title": "array_to_latex", + "url": "/api/qiskit/1.0/qiskit.visualization.array_to_latex" + }, + { + "title": "circuit_drawer", + "url": "/api/qiskit/1.0/qiskit.visualization.circuit_drawer" + }, + { + "title": "dag_drawer", + "url": "/api/qiskit/1.0/qiskit.visualization.dag_drawer" + }, + { + "title": "pass_manager_drawer", + "url": "/api/qiskit/1.0/qiskit.visualization.pass_manager_drawer" + }, + { + "title": "plot_bloch_multivector", + "url": "/api/qiskit/1.0/qiskit.visualization.plot_bloch_multivector" + }, + { + "title": "plot_bloch_vector", + "url": "/api/qiskit/1.0/qiskit.visualization.plot_bloch_vector" + }, + { + "title": "plot_circuit_layout", + "url": "/api/qiskit/1.0/qiskit.visualization.plot_circuit_layout" + }, + { + "title": "plot_coupling_map", + "url": "/api/qiskit/1.0/qiskit.visualization.plot_coupling_map" + }, + { + "title": "plot_distribution", + "url": "/api/qiskit/1.0/qiskit.visualization.plot_distribution" + }, + { + "title": "plot_error_map", + "url": "/api/qiskit/1.0/qiskit.visualization.plot_error_map" + }, + { + "title": "plot_gate_map", + "url": "/api/qiskit/1.0/qiskit.visualization.plot_gate_map" + }, + { + "title": "plot_histogram", + "url": "/api/qiskit/1.0/qiskit.visualization.plot_histogram" + }, + { + "title": "plot_state_city", + "url": "/api/qiskit/1.0/qiskit.visualization.plot_state_city" + }, + { + "title": "plot_state_hinton", + "url": "/api/qiskit/1.0/qiskit.visualization.plot_state_hinton" + }, + { + "title": "plot_state_paulivec", + "url": "/api/qiskit/1.0/qiskit.visualization.plot_state_paulivec" + }, + { + "title": "plot_state_qsphere", + "url": "/api/qiskit/1.0/qiskit.visualization.plot_state_qsphere" + }, + { + "title": "timeline_drawer", + "url": "/api/qiskit/1.0/qiskit.visualization.timeline_drawer" + }, + { + "title": "visualize_transition", + "url": "/api/qiskit/1.0/qiskit.visualization.visualize_transition" + } + ] + } + ] + }, + { + "title": "Serialization (OpenQASM and QPY)", + "children": [ + { + "title": "qiskit.qasm2", + "url": "/api/qiskit/1.0/qasm2" + }, + { + "title": "qiskit.qasm3", + "url": "/api/qiskit/1.0/qasm3" + }, + { + "title": "qiskit.qpy", + "url": "/api/qiskit/1.0/qpy" + } + ] + }, + { + "title": "Pulse-level programming", + "children": [ + { + "title": "qiskit.pulse", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/pulse" + }, + { + "title": "Acquire", + "url": "/api/qiskit/1.0/qiskit.pulse.instructions.Acquire" + }, + { + "title": "AcquireChannel", + "url": "/api/qiskit/1.0/qiskit.pulse.channels.AcquireChannel" + }, + { + "title": "AlignEquispaced", + "url": "/api/qiskit/1.0/qiskit.pulse.transforms.AlignEquispaced" + }, + { + "title": "AlignFunc", + "url": "/api/qiskit/1.0/qiskit.pulse.transforms.AlignFunc" + }, + { + "title": "AlignLeft", + "url": "/api/qiskit/1.0/qiskit.pulse.transforms.AlignLeft" + }, + { + "title": "AlignRight", + "url": "/api/qiskit/1.0/qiskit.pulse.transforms.AlignRight" + }, + { + "title": "AlignSequential", + "url": "/api/qiskit/1.0/qiskit.pulse.transforms.AlignSequential" + }, + { + "title": "Constant", + "url": "/api/qiskit/1.0/qiskit.pulse.library.Constant_class.rst" + }, + { + "title": "ControlChannel", + "url": "/api/qiskit/1.0/qiskit.pulse.channels.ControlChannel" + }, + { + "title": "Cos", + "url": "/api/qiskit/1.0/qiskit.pulse.library.Cos_class.rst" + }, + { + "title": "Delay", + "url": "/api/qiskit/1.0/qiskit.pulse.instructions.Delay" + }, + { + "title": "Drag", + "url": "/api/qiskit/1.0/qiskit.pulse.library.Drag_class.rst" + }, + { + "title": "DriveChannel", + "url": "/api/qiskit/1.0/qiskit.pulse.channels.DriveChannel" + }, + { + "title": "Gaussian", + "url": "/api/qiskit/1.0/qiskit.pulse.library.Gaussian_class.rst" + }, + { + "title": "gaussian_square_echo", + "url": "/api/qiskit/1.0/qiskit.pulse.library.gaussian_square_echo" + }, + { + "title": "GaussianDeriv", + "url": "/api/qiskit/1.0/qiskit.pulse.library.GaussianDeriv" + }, + { + "title": "GaussianSquare", + "url": "/api/qiskit/1.0/qiskit.pulse.library.GaussianSquare" + }, + { + "title": "GaussianSquareDrag", + "url": "/api/qiskit/1.0/qiskit.pulse.library.GaussianSquareDrag" + }, + { + "title": "InstructionScheduleMap", + "url": "/api/qiskit/1.0/qiskit.pulse.InstructionScheduleMap" + }, + { + "title": "MeasureChannel", + "url": "/api/qiskit/1.0/qiskit.pulse.channels.MeasureChannel" + }, + { + "title": "MemorySlot", + "url": "/api/qiskit/1.0/qiskit.pulse.channels.MemorySlot" + }, + { + "title": "Play", + "url": "/api/qiskit/1.0/qiskit.pulse.instructions.Play" + }, + { + "title": "Reference", + "url": "/api/qiskit/1.0/qiskit.pulse.instructions.Reference" + }, + { + "title": "RegisterSlot", + "url": "/api/qiskit/1.0/qiskit.pulse.channels.RegisterSlot" + }, + { + "title": "RelativeBarrier", + "url": "/api/qiskit/1.0/qiskit.pulse.instructions.RelativeBarrier" + }, + { + "title": "Sawtooth", + "url": "/api/qiskit/1.0/qiskit.pulse.library.Sawtooth_class.rst" + }, + { + "title": "Schedule", + "url": "/api/qiskit/1.0/qiskit.pulse.Schedule" + }, + { + "title": "ScheduleBlock", + "url": "/api/qiskit/1.0/qiskit.pulse.ScheduleBlock" + }, + { + "title": "Sech", + "url": "/api/qiskit/1.0/qiskit.pulse.library.Sech_fun.rst" + }, + { + "title": "SechDeriv", + "url": "/api/qiskit/1.0/qiskit.pulse.library.SechDeriv" + }, + { + "title": "SetFrequency", + "url": "/api/qiskit/1.0/qiskit.pulse.instructions.SetFrequency" + }, + { + "title": "SetPhase", + "url": "/api/qiskit/1.0/qiskit.pulse.instructions.SetPhase" + }, + { + "title": "ShiftFrequency", + "url": "/api/qiskit/1.0/qiskit.pulse.instructions.ShiftFrequency" + }, + { + "title": "ShiftPhase", + "url": "/api/qiskit/1.0/qiskit.pulse.instructions.ShiftPhase" + }, + { + "title": "Sin", + "url": "/api/qiskit/1.0/qiskit.pulse.library.Sin_class.rst" + }, + { + "title": "Snapshot", + "url": "/api/qiskit/1.0/qiskit.pulse.instructions.Snapshot" + }, + { + "title": "SnapshotChannel", + "url": "/api/qiskit/1.0/qiskit.pulse.channels.SnapshotChannel" + }, + { + "title": "Square", + "url": "/api/qiskit/1.0/qiskit.pulse.library.Square_fun.rst" + }, + { + "title": "SymbolicPulse", + "url": "/api/qiskit/1.0/qiskit.pulse.library.SymbolicPulse" + }, + { + "title": "TimeBlockade", + "url": "/api/qiskit/1.0/qiskit.pulse.instructions.TimeBlockade" + }, + { + "title": "Triangle", + "url": "/api/qiskit/1.0/qiskit.pulse.library.Triangle_class.rst" + }, + { + "title": "Waveform", + "url": "/api/qiskit/1.0/qiskit.pulse.library.Waveform" + } + ] + }, + { + "title": "qiskit.scheduler", + "url": "/api/qiskit/1.0/scheduler" + } + ] + }, + { + "title": "Other", + "children": [ + { + "title": "qiskit.assembler", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/assembler" + }, + { + "title": "RunConfig", + "url": "/api/qiskit/1.0/qiskit.assembler.RunConfig" + } + ] + }, + { + "title": "qiskit.compiler", + "url": "/api/qiskit/1.0/compiler" + }, + { + "title": "qiskit.exceptions", + "url": "/api/qiskit/1.0/exceptions" + }, + { + "title": "qiskit.qobj", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit/1.0/qobj" + }, + { + "title": "GateCalibration", + "url": "/api/qiskit/1.0/qiskit.qobj.GateCalibration" + }, + { + "title": "PulseLibraryItem", + "url": "/api/qiskit/1.0/qiskit.qobj.PulseLibraryItem" + }, + { + "title": "PulseQobj", + "url": "/api/qiskit/1.0/qiskit.qobj.PulseQobj" + }, + { + "title": "PulseQobjConfig", + "url": "/api/qiskit/1.0/qiskit.qobj.PulseQobjConfig" + }, + { + "title": "PulseQobjExperiment", + "url": "/api/qiskit/1.0/qiskit.qobj.PulseQobjExperiment" + }, + { + "title": "PulseQobjExperimentConfig", + "url": "/api/qiskit/1.0/qiskit.qobj.PulseQobjExperimentConfig" + }, + { + "title": "PulseQobjInstruction", + "url": "/api/qiskit/1.0/qiskit.qobj.PulseQobjInstruction" + }, + { + "title": "QasmExperimentCalibrations", + "url": "/api/qiskit/1.0/qiskit.qobj.QasmExperimentCalibrations" + }, + { + "title": "QasmQobj", + "url": "/api/qiskit/1.0/qiskit.qobj.QasmQobj" + }, + { + "title": "QasmQobjConfig", + "url": "/api/qiskit/1.0/qiskit.qobj.QasmQobjConfig" + }, + { + "title": "QasmQobjExperiment", + "url": "/api/qiskit/1.0/qiskit.qobj.QasmQobjExperiment" + }, + { + "title": "QasmQobjExperimentConfig", + "url": "/api/qiskit/1.0/qiskit.qobj.QasmQobjExperimentConfig" + }, + { + "title": "QasmQobjInstruction", + "url": "/api/qiskit/1.0/qiskit.qobj.QasmQobjInstruction" + }, + { + "title": "QobjExperimentHeader", + "url": "/api/qiskit/1.0/qiskit.qobj.QobjExperimentHeader" + }, + { + "title": "QobjHeader", + "url": "/api/qiskit/1.0/qiskit.qobj.QobjHeader" + }, + { + "title": "QobjMeasurementOption", + "url": "/api/qiskit/1.0/qiskit.qobj.QobjMeasurementOption" + } + ] + }, + { + "title": "qiskit.utils", + "url": "/api/qiskit/1.0/utils" + } + ] + }, + { + "title": "Release notes", + "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, + { + "title": "1.0", + "url": "/api/qiskit/release-notes/1.0" + }, + { + "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/1.0/assembler.mdx b/docs/api/qiskit/1.0/assembler.mdx new file mode 100644 index 00000000000..cee333c62c8 --- /dev/null +++ b/docs/api/qiskit/1.0/assembler.mdx @@ -0,0 +1,180 @@ +--- +title: assembler +description: API reference for qiskit.assembler +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit.assembler +--- + + + + + + + +# Circuit and Schedule Assembler + + + +`qiskit.assembler` + +## Circuit Assembler + +### assemble\_circuits + + + 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 + + + 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 + + + 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/1.0/circuit.mdx b/docs/api/qiskit/1.0/circuit.mdx new file mode 100644 index 00000000000..a4973d37325 --- /dev/null +++ b/docs/api/qiskit/1.0/circuit.mdx @@ -0,0 +1,353 @@ +--- +title: circuit +description: API reference for qiskit.circuit +in_page_toc_min_heading_level: 2 +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/1.0/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/1.0/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/1.0/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/1.0/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/1.0/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") | 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. | + +### Annotated Operations + +| | | +| ----------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------- | +| [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")(base\_op, modifiers) | Annotated operation. | +| [`InverseModifier`](qiskit.circuit.InverseModifier "qiskit.circuit.InverseModifier")() | Inverse modifier: specifies that the operation is inverted. | +| [`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`. | + +### 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. | + +### Gate Commutation + +| | | +| ----------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------- | +| [`CommutationChecker`](qiskit.circuit.CommutationChecker "qiskit.circuit.CommutationChecker")(\[...]) | This code is essentially copy-pasted from commutative\_analysis.py. | + +### Random Circuits + +#### random\_circuit + + + 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/1.0/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 + + +### 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 + + + Base class for errors raised while processing a circuit. + + Set the error message. + + diff --git a/docs/api/qiskit/1.0/circuit_classical.mdx b/docs/api/qiskit/1.0/circuit_classical.mdx new file mode 100644 index 00000000000..8bb7ae3dc49 --- /dev/null +++ b/docs/api/qiskit/1.0/circuit_classical.mdx @@ -0,0 +1,938 @@ +--- +title: classical +description: API reference for qiskit.circuit.classical +in_page_toc_min_heading_level: 2 +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: + +#### Expr + + + 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. + +#### Var + + + A classical variable. + + Variables are immutable after construction, so they can be used as dictionary keys. + + +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. + +#### Value + + + 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. + +#### Unary + + + 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 + + + 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 + + + Bitwise negation. `~operand`. + + + ###### LOGIC\_NOT + + + Logical negation. `!operand`. + + + + +#### Binary + + + 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 + + + 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 + + + Bitwise “and”. `lhs & rhs`. + + + ###### BIT\_OR + + + Bitwise “or”. `lhs | rhs`. + + + ###### BIT\_XOR + + + Bitwise “exclusive or”. `lhs ^ rhs`. + + + ###### LOGIC\_AND + + + Logical “and”. `lhs && rhs`. + + + ###### LOGIC\_OR + + + Logical “or”. `lhs || rhs`. + + + ###### EQUAL + + + Numeric equality. `lhs == rhs`. + + + ###### NOT\_EQUAL + + + Numeric inequality. `lhs != rhs`. + + + ###### LESS + + + Numeric less than. `lhs < rhs`. + + + ###### LESS\_EQUAL + + + Numeric less than or equal to. `lhs <= rhs` + + + ###### GREATER + + + Numeric greater than. `lhs > rhs`. + + + ###### GREATER\_EQUAL + + + 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. + +#### Cast + + + 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. If you want to directly use some scalar value as an [`Expr`](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") node, you can manually [`lift()`](#qiskit.circuit.classical.expr.lift "qiskit.circuit.classical.expr.lift") it yourself. + +#### lift + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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. + +#### ExprVisitor + + + 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 + + + **Return type** + + *\_T\_co* + + + ##### visit\_cast + + + **Return type** + + *\_T\_co* + + + ##### visit\_generic + + + **Return type** + + *\_T\_co* + + + ##### visit\_unary + + + **Return type** + + *\_T\_co* + + + ##### visit\_value + + + **Return type** + + *\_T\_co* + + + ##### visit\_var + + + **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 + + + 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 + + + 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` + + + +### Representation + +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: + +#### Type + + + 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). + +#### Bool + + + The Boolean type. This has exactly two values: `True` and `False`. + + +#### Uint + + + 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. + +### Working with types + +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. + +#### Partial ordering of types + +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 + + + 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. + +##### Ordering + + + 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 + + + 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 + + + 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 + + + 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) + ``` + + +#### Casting between types + +It is common to need to cast values of one type to another type. The casting rules for this are embedded into the [`types`](https://docs.python.org/3/library/types.html#module-types "(in Python v3.12)") module. You can query the casting kinds using [`cast_kind()`](#qiskit.circuit.classical.types.cast_kind "qiskit.circuit.classical.types.cast_kind"): + +##### cast\_kind + + + Determine the sort of cast that is required to move from the left type to the right type. + + **Examples** + + ```python + >>> from qiskit.circuit.classical import types + >>> types.cast_kind(types.Bool(), types.Bool()) + + >>> types.cast_kind(types.Uint(8), types.Bool()) + + >>> types.cast_kind(types.Bool(), types.Uint(8)) + + >>> types.cast_kind(types.Uint(16), types.Uint(8)) + + ``` + + **Return type** + + [*CastKind*](#qiskit.circuit.classical.types.CastKind "qiskit.circuit.classical.types.ordering.CastKind") + + +The return values from this function are an enumeration explaining the types of cast that are allowed from the left type to the right type. + +##### CastKind + + + A return value indicating the type of cast that can occur from one type to another. + + diff --git a/docs/api/qiskit/1.0/circuit_library.mdx b/docs/api/qiskit/1.0/circuit_library.mdx new file mode 100644 index 00000000000..6185f1d6b87 --- /dev/null +++ b/docs/api/qiskit/1.0/circuit_library.mdx @@ -0,0 +1,1150 @@ +--- +title: library +description: API reference for qiskit.circuit.library +in_page_toc_min_heading_level: 2 +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/1.0/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")(\*args\[, \_force\_mutable]) | Quantum measurement in the computational basis. | +| [`Reset`](qiskit.circuit.library.Reset "qiskit.circuit.library.Reset")(\*args\[, \_force\_mutable]) | 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 $\vec{v}$ where $\|\vec{v}\|_2$ 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. | +| [`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. | +| [`EvolvedOperatorAnsatz`](qiskit.circuit.library.EvolvedOperatorAnsatz "qiskit.circuit.library.EvolvedOperatorAnsatz")(\[operators, reps, ...]) | The evolved operator ansatz. | +| [`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 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_2a\_2 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_2a\_3 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_4a\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_4a\_2 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_4a\_3 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_4b\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_4b\_2 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_5a\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_5a\_2 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_5a\_3 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_5a\_4 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_6a\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_6a\_2 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_6a\_3 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_6a\_4 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_6b\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_6b\_2 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_6c\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_7a\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_7b\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_7c\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_7d\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_7e\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9a\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9c\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9c\_2 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9c\_3 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9c\_4 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9c\_5 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9c\_6 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9c\_7 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9c\_8 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9c\_9 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9c\_10 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9c\_11 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9c\_12 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9d\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9d\_2 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9d\_3 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9d\_4 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9d\_5 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9d\_6 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9d\_7 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9d\_8 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9d\_9 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### template\_nct\_9d\_10 + + + **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 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_2\_2 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_2\_3 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_2\_4 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_3\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_4\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_4\_2 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_4\_3 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_4\_4 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_5\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_6\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_6\_2 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_6\_3 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_6\_4 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_6\_5 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_8\_1 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_8\_2 + + + **Returns** + + template as a quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +#### clifford\_8\_3 + + + **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 + + + Template for CX - RYGate - CX. + + +#### rzx\_xz + + + Template for CX - RXGate - CX. + + +#### rzx\_cy + + + Template for CX - RYGate - CX. + + +#### rzx\_zz1 + + + Template for CX - RZGate - CX. + + +#### rzx\_zz2 + + + Template for CX - RZGate - CX. + + +#### rzx\_zz3 + + + Template for CX - RZGate - CX. + + diff --git a/docs/api/qiskit/1.0/circuit_singleton.mdx b/docs/api/qiskit/1.0/circuit_singleton.mdx new file mode 100644 index 00000000000..ee91fb85a10 --- /dev/null +++ b/docs/api/qiskit/1.0/circuit_singleton.mdx @@ -0,0 +1,208 @@ +--- +title: singleton +description: API reference for qiskit.circuit.singleton +in_page_toc_min_heading_level: 2 +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. + +### SingletonInstruction + + + 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. + + +### SingletonGate + + + 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. + + +### SingletonControlledGate + + + 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 + + + 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/1.0/classicalfunction.mdx b/docs/api/qiskit/1.0/classicalfunction.mdx new file mode 100644 index 00000000000..2283ac9ce87 --- /dev/null +++ b/docs/api/qiskit/1.0/classicalfunction.mdx @@ -0,0 +1,84 @@ +--- +title: classicalfunction +description: API reference for qiskit.circuit.classicalfunction +in_page_toc_min_heading_level: 2 +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/1.0/compiler.mdx b/docs/api/qiskit/1.0/compiler.mdx new file mode 100644 index 00000000000..e73dfef4e38 --- /dev/null +++ b/docs/api/qiskit/1.0/compiler.mdx @@ -0,0 +1,304 @@ +--- +title: compiler +description: API reference for qiskit.compiler +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit.compiler +--- + + + + + + + +# Compilation Routines + + + +`qiskit.compiler` + +## Circuit and Pulse Compilation Functions + +### assemble + + + 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 + + + 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 + + + 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’, ‘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_method` 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*](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.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. + + * **num\_processes** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The maximum number of parallel processes to launch for this call to transpile if parallel execution is enabled. This argument overrides `num_processes` in the user configuration file, and the `QISKIT_NUM_PROCS` environment variable. If set to `None` the system default or local user configuration will be used. + + **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 + + + 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/1.0/converters.mdx b/docs/api/qiskit/1.0/converters.mdx new file mode 100644 index 00000000000..7a68587f996 --- /dev/null +++ b/docs/api/qiskit/1.0/converters.mdx @@ -0,0 +1,248 @@ +--- +title: converters +description: API reference for qiskit.converters +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit.converters +--- + + + + + + + +# Circuit Converters + + + +`qiskit.converters` + +### circuit\_to\_dag + + + 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 + + + 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/1.0/converters-1.png) + + +### circuit\_to\_instruction + + + 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 + + + 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") + + +### dagdependency\_to\_circuit + + + 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 + + + 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 + + + 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 + + + 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/1.0/dagcircuit.mdx b/docs/api/qiskit/1.0/dagcircuit.mdx new file mode 100644 index 00000000000..048c2818175 --- /dev/null +++ b/docs/api/qiskit/1.0/dagcircuit.mdx @@ -0,0 +1,50 @@ +--- +title: dagcircuit +description: API reference for qiskit.dagcircuit +in_page_toc_min_heading_level: 2 +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 + + + Base class for errors raised by the DAGCircuit object. + + Set the error message. + + +### DAGDependencyError + + + Base class for errors raised by the DAGDependency object. + + Set the error message. + + diff --git a/docs/api/qiskit/1.0/exceptions.mdx b/docs/api/qiskit/1.0/exceptions.mdx new file mode 100644 index 00000000000..331e9146494 --- /dev/null +++ b/docs/api/qiskit/1.0/exceptions.mdx @@ -0,0 +1,107 @@ +--- +title: exceptions +description: API reference for qiskit.exceptions +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit.exceptions +--- + + + + + + + +# Top-level exceptions + + + +`qiskit.exceptions` + +## Exceptions + +All Qiskit-related exceptions raised by Qiskit are subclasses of the base: + +### QiskitError + + + 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 + + + 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 + + + Raised when an error is encountered reading a user config file. + + Set the error message. + + +### InvalidFileError + + + Raised when the file provided is not valid for the specific task. + + Set the error message. + + +## Warnings + +Some particular features of Qiskit may raise custom warnings. In general, Qiskit will use built-in Python warnings (such as [`DeprecationWarning`](https://docs.python.org/3/library/exceptions.html#DeprecationWarning "(in Python v3.12)")) when appropriate, but warnings related to Qiskit-specific functionality will be subtypes of [`QiskitWarning`](#qiskit.exceptions.QiskitWarning "qiskit.exceptions.QiskitWarning"). + +### QiskitWarning + + + Common subclass of warnings for Qiskit-specific warnings being raised. + + +Related to [`MissingOptionalLibraryError`](#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError"), in some cases an optional dependency might be found, but fail to import for some other reason. In this case, Qiskit will continue as if the dependency is not present, but will raise [`OptionalDependencyImportWarning`](#qiskit.exceptions.OptionalDependencyImportWarning "qiskit.exceptions.OptionalDependencyImportWarning") to let you know about it. + +### OptionalDependencyImportWarning + + + Raised when an optional library raises errors during its import. + + +When experimental features are being used, Qiskit will raise [`ExperimentalWarning`](#qiskit.exceptions.ExperimentalWarning "qiskit.exceptions.ExperimentalWarning"). + + + Qiskit experimental features can break at any minor release and their API might change without previous notification. Their use is not recommended in production. + + +### ExperimentalWarning + + + Raised when an experimental feature is being used. + + +### Filtering warnings + +Python has built-in mechanisms to filter warnings, described in the documentation of the [`warnings`](https://docs.python.org/3/library/warnings.html#module-warnings "(in Python v3.12)") module. You can use these subclasses in your warning filters from within Python to silence warnings you are not interested in. For example, if you are knowingly using experimental features and are comfortable that they make break in later versions, you can silence [`ExperimentalWarning`](#qiskit.exceptions.ExperimentalWarning "qiskit.exceptions.ExperimentalWarning") like this: + +```python +import warnings +from qiskit.exceptions import ExperimentalWarning + +warnings.filterwarnings("ignore", category=ExperimentalWarning) +``` + diff --git a/docs/api/qiskit/1.0/index.mdx b/docs/api/qiskit/1.0/index.mdx new file mode 100644 index 00000000000..7e20f134155 --- /dev/null +++ b/docs/api/qiskit/1.0/index.mdx @@ -0,0 +1,47 @@ +--- +title: qiskit +description: API reference for qiskit +in_page_toc_min_heading_level: 2 +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) +* [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) +* [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) +* [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) +* [Qobj (`qiskit.qobj`)](qobj) +* [QPY serialization (`qiskit.qpy`)](qpy) +* [Quantum Information (`qiskit.quantum_info`)](quantum_info) +* [Experiment Results (`qiskit.result`)](result) +* [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) +* [Utilities (`qiskit.utils`)](utils) +* [Top-level exceptions (`qiskit.exceptions`)](exceptions) + diff --git a/docs/api/qiskit/1.0/passmanager.mdx b/docs/api/qiskit/1.0/passmanager.mdx new file mode 100644 index 00000000000..1f11d938c56 --- /dev/null +++ b/docs/api/qiskit/1.0/passmanager.mdx @@ -0,0 +1,170 @@ +--- +title: passmanager +description: API reference for qiskit.passmanager +in_page_toc_min_heading_level: 2 +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 [`parallel_map()`](utils#qiskit.utils.parallel_map "qiskit.utils.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 + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------- | +| [`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 + + + Pass manager error. + + Set the error message. + + diff --git a/docs/api/qiskit/1.0/primitives.mdx b/docs/api/qiskit/1.0/primitives.mdx new file mode 100644 index 00000000000..c6dd3a4c47c --- /dev/null +++ b/docs/api/qiskit/1.0/primitives.mdx @@ -0,0 +1,351 @@ +--- +title: primitives +description: API reference for qiskit.primitives +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit.primitives +--- + + + + + + + +# Primitives + + + +`qiskit.primitives` + +The primitives are computational building blocks to be used in larger applications whose input units, called primitive unified blocs (PUBs), require quantum resources to efficiently produce outputs for. + +Currently there are two types of primitives whose abstractions, in their latest versions, are defined by [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") and [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2"). Samplers are responsible for accepting quantum circuits (or sweeps of values over parameterized circuits) and sampling from their classical output registers. Estimators accept combinations of circuits and observables (or sweeps thereof) to estimate expectation values of the observables. + +Qiskit implements a reference implementation for each of these abstractions, [`StatevectorSampler`](qiskit.primitives.StatevectorSampler "qiskit.primitives.StatevectorSampler") and [`StatevectorEstimator`](qiskit.primitives.StatevectorEstimator "qiskit.primitives.StatevectorEstimator"). + +## Overview of EstimatorV2 + +[`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") is a primitive that estimates expectation values for provided quantum circuit and observable combinations. + +Following construction, an estimator is used by calling its [`run()`](qiskit.primitives.BaseEstimatorV2#run "qiskit.primitives.BaseEstimatorV2.run") method with a list of pubs (Primitive Unified Blocs). Each pub contains three values that, together, define a computation unit of work for the estimator to complete: + +* a single [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), possibly parametrized, whose final state we define as $\psi(\theta)$, +* one or more observables (specified as any `ObservablesArrayLike`, including [`Pauli`](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli"), [`SparsePauliOp`](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp"), `str`) that specify which expectation values to estimate, denoted $H_j$, and +* a collection parameter value sets to bind the circuit against, $\theta_k$. + +Running an estimator returns a [`BasePrimitiveJob`](qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob") object, where calling the method [`result()`](qiskit.primitives.BasePrimitiveJob#result "qiskit.primitives.BasePrimitiveJob.result") results in expectation value estimates and metadata for each pub: + +$$ +\langle\psi(\theta_k)|H_j|\psi(\theta_k)\rangle +$$ + +The observables and parameter values portion of a pub can be array-valued with arbitrary dimensions, where standard broadcasting rules are applied, so that, in turn, the estimated result for each pub is in general array-valued as well. For more information, please check [here](https://github.com/Qiskit/RFCs/blob/master/0015-estimator-interface.md#arrays-and-broadcasting-). + +Here is an example of how an estimator is used. + +```python +from qiskit.primitives import StatevectorEstimator as 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, hamiltonian1, [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, [hamiltonian1, hamiltonian3], [theta1, theta3]), + (psi2, hamiltonian2, theta2) + ], + precision=0.01 +) +job_result = job2.result() +print(f"The primitive-job finished with result {job_result}") +``` + +## Overview of SamplerV2 + +[`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") is a primitive that samples outputs of quantum circuits. + +Following construction, a sampler is used by calling its [`run()`](qiskit.primitives.BaseSamplerV2#run "qiskit.primitives.BaseSamplerV2.run") method with a list of pubs (Primitive Unified Blocs). Each pub contains values that, together, define a computational unit of work for the sampler to complete: + +* A single [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), possibly parameterized. +* A collection parameter value sets to bind the circuit against if it is parametric. +* Optionally, the number of shots to sample, determined in the run method if not set. + +Running an estimator returns a [`BasePrimitiveJob`](qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob") object, where calling the method [`result()`](qiskit.primitives.BasePrimitiveJob#result "qiskit.primitives.BasePrimitiveJob.result") results in output samples and metadata for each pub. + +Here is an example of how a sampler is used. + +```python +from qiskit.primitives import StatevectorSampler as Sampler +from qiskit import QuantumCircuit +from qiskit.circuit.library import RealAmplitudes + +# create a Bell circuit +bell = QuantumCircuit(2) +bell.h(0) +bell.cx(0, 1) +bell.measure_all() + +# create 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() + +# collect 128 shots from the Bell circuit +job = sampler.run([bell], shots=128) +job_result = job.result() +print(f"The primitive-job finished with result {job_result}")) + +# run a sampler job on the parameterized circuits +job2 = sampler.run([(pqc, theta1), (pqc2, theta2)] +job_result = job2.result() +print(f"The primitive-job finished with result {job_result}")) +``` + +## Overview of EstimatorV1 + +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 SamplerV1 + +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]) +``` + +## Migration from Primitives V1 to V2 + +The formal distinction between the Primitives V1 and V2 APIs are the base classes from which primitives implementations inherit, which are all listed at the bottom of the page. At a conceptual level, however, here are some notable differences keep in mind when migrating from V1 to V2: + +1. The V2 primitives favour vectorized inputs, where single circuits can be grouped with vector-valued (or more generally, array-valued) specifications. Each group is called a primitive unified bloc (pub), and each pub gets its own result. For example, in the estimator, you can compare the following differences: + + ```python + # Favoured V2 pattern. There is only one pub here, but there could be more. + job = estimator_v2.run([(circuit, [obs1, obs2, obs3, obs4])]) + evs = job.result()[0].data.evs + + # V1 equivalent, where the same circuit must be provided four times. + job = estimator_v1.run([circuit] * 4, [obs1, obs2, obs3, obs4]) + evs = job.result().values + ``` + + Not shown in the above example, for brevity, is that the circuit can be parametric, with arrays of parameter value sets broadcasted against the array of observables. The sampler is similar, but with no observables: + + ```python + # Favoured V2 pattern. There is only one pub here, but there could be more. + job = sampler_v2.run([(circuit, [vals1, vals2, vals3])]) + samples = job.result()[0].data + + # V1 equivalent, where the same circuit must be provided three times. + sampler_v1.run([circuit] * 3, [vals1, vals2, vals3]) + quasi_dists = job.result().quasi_dists + ``` + +2. The V2 sampler returns samples of classical outcomes, preserving the shot order in which they were measured. This is in contrast to the V1 sampler that outputs quasi-probability distributions which are instead an *estimate of the distribution* over classical outcomes. Moreover, the V2 sampler result objects organize data in terms of their input circuits’ classical register names, which provides natural compatibility with dynamic circuits. + + The closest analog of quasi-probability distributions in the V2 interface is the [`get_counts()`](qiskit.primitives.BitArray#get_counts "qiskit.primitives.BitArray.get_counts") method, shown in the example below. However, we emphasize that for utility scale experiments (100+ qubits), the chances of measuring the same bitstring twice are small, so that binning like counts in a dictionary format will not typically be an efficient data processing strategy. + + ```python + circuit = QuantumCircuit(QuantumRegister(2, "qreg"), ClassicalRegister(2, "alpha")) + circuit.h(0) + circuit.cx(0, 1) + circuit.measure([0, 1], [0, 1]) + + # V1 sampler usage + result = sampler_v1.run([circuit]).result() + quasi_dist = result.quasi_dists[0] + + # V2 sampler usage + result = sampler_v2.run([circuit]).result() + # these are the bit values from the alpha register, over all shots + bitvals = result[0].data.alpha + # we can use it to generate a Counts mapping, which is similar to a quasi prob distribution + counts = bitvals.get_counts() + # which can in turn be converted to the V1 type through normalization + quasi_dist = QuasiDistribution({outcome: freq / shots for outcome, freq in counts.items()}) + ``` + +3. The V2 primitives have brought the concept of sampling overhead, inherent to all quantum systems via their inherent probabilistic nature, out of the options and into the API itself. For the sampler, this means that the `shots` argument is now part of the [`run()`](qiskit.primitives.BaseSamplerV2#run "qiskit.primitives.BaseSamplerV2.run") signature, and moreover that each pub is able to specify its own value for `shots`, which takes precedence over any value given to the method. The sampler has an analogous `precision` argument that specifies the error bars that the primitive implementation should target for expectation values estimates. + + This concept is not present in the API of the V1 primitives, though all implementations of the V1 primitives have related settings somewhere in their options. + + ```python + # Sample two circuits at 128 shots each. + sampler_v2.run([circuit1, circuit2], shots=128) + + # Sample two circuits at different amounts of shots. The "None"s are necessary as placeholders + # for the lack of parameter values in this example. + sampler_v2.run([(circuit1, None, 123), (circuit2, None, 456)]) + + # Estimate expectation values for two pubs, both with 0.05 precision. + estimator_v2.run([(circuit1, obs_array1), (circuit2, obs_array_2)], precision=0.05) + ``` + +## Primitives API + +### Primitives V2 + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------ | +| [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2")() | Estimator V2 base class. | +| [`StatevectorEstimator`](qiskit.primitives.StatevectorEstimator "qiskit.primitives.StatevectorEstimator")(\*\[, default\_precision, ...]) | Simple implementation of [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") with full state vector simulation. | + +### Sampler V2 + +| | | +| -------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2")() | Sampler V2 base class. | +| [`StatevectorSampler`](qiskit.primitives.StatevectorSampler "qiskit.primitives.StatevectorSampler")(\*\[, default\_shots, seed]) | Simple implementation of [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") using full state vector simulation. | + +### Results V2 + +| | | +| --------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------- | +| [`BitArray`](qiskit.primitives.BitArray "qiskit.primitives.BitArray")(array, num\_bits) | Stores an array of bit values. | +| [`DataBin`](qiskit.primitives.DataBin "qiskit.primitives.DataBin")() | Base class for data bin containers. | +| [`PrimitiveResult`](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")(pub\_results\[, metadata]) | A container for multiple pub results and global metadata. | +| [`PubResult`](qiskit.primitives.PubResult "qiskit.primitives.PubResult")(data\[, metadata]) | Result of Primitive Unified Bloc. | +| [`BasePrimitiveJob`](qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob")(job\_id, \*\*kwargs) | Primitive job abstract base class. | +| [`PrimitiveJob`](qiskit.primitives.PrimitiveJob "qiskit.primitives.PrimitiveJob")(function, \*args, \*\*kwargs) | Primitive job class for the reference implementations of Primitives. | + +### Estimator V1 + +| | | +| ----------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------- | +| [`BaseEstimator`](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator") | alias of [`BaseEstimatorV1`](qiskit.primitives.BaseEstimatorV1 "qiskit.primitives.base.base_estimator.BaseEstimatorV1") | +| [`BaseEstimatorV1`](qiskit.primitives.BaseEstimatorV1 "qiskit.primitives.BaseEstimatorV1")(\*\[, options]) | Estimator V1 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. | +| [`EstimatorResult`](qiskit.primitives.EstimatorResult "qiskit.primitives.EstimatorResult")(values, metadata) | Result of Estimator. | + +### Sampler V1 + +| | | +| ----------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------- | +| [`BaseSampler`](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") | alias of [`BaseSamplerV1`](qiskit.primitives.BaseSamplerV1 "qiskit.primitives.base.base_sampler.BaseSamplerV1") | +| [`BaseSamplerV1`](qiskit.primitives.BaseSamplerV1 "qiskit.primitives.BaseSamplerV1")(\*\[, options]) | Sampler V1 base class | +| [`Sampler`](qiskit.primitives.Sampler "qiskit.primitives.Sampler")(\*\[, options]) | Sampler class. | +| [`BackendSampler`](qiskit.primitives.BackendSampler "qiskit.primitives.BackendSampler")(backend\[, options, ...]) | A `BaseSampler` implementation that provides an interface for leveraging the sampler interface from any backend. | +| [`SamplerResult`](qiskit.primitives.SamplerResult "qiskit.primitives.SamplerResult")(quasi\_dists, metadata) | Result of Sampler. | + diff --git a/docs/api/qiskit/1.0/providers.mdx b/docs/api/qiskit/1.0/providers.mdx new file mode 100644 index 00000000000..69149be6712 --- /dev/null +++ b/docs/api/qiskit/1.0/providers.mdx @@ -0,0 +1,499 @@ +--- +title: providers +description: API reference for qiskit.providers +in_page_toc_min_heading_level: 2 +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.github.io/qiskit-aer/stubs/qiskit_aer.AerSimulator.html#qiskit_aer.AerSimulator "(in Qiskit Aer v0.14.0)") 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\[, ...]) | Decode transpiler target from backend data set. | + +### 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 + + + Base class for errors raised while looking for a backend. + + Set the error message. + + +#### BackendPropertyError + + + Base class for errors raised while looking for a backend property. + + Set the error message. + + +#### JobError + + + Base class for errors raised by Jobs. + + Set the error message. + + +#### JobTimeoutError + + + Base class for timeout errors raised by jobs. + + Set the error message. + + +#### BackendConfigurationError + + + 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 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 IBM backends from the `qiskit-ibm-provider` package this involves converting from a quantum circuit and options into a [`qpy`](qpy#module-qiskit.qpy "qiskit.qpy") payload embedded in JSON 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` and `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 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/1.0/providers_basic_provider.mdx b/docs/api/qiskit/1.0/providers_basic_provider.mdx new file mode 100644 index 00000000000..eb5dc6f06c2 --- /dev/null +++ b/docs/api/qiskit/1.0/providers_basic_provider.mdx @@ -0,0 +1,52 @@ +--- +title: basic_provider +description: API reference for qiskit.providers.basic_provider +in_page_toc_min_heading_level: 2 +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/1.0/providers_fake_provider.mdx b/docs/api/qiskit/1.0/providers_fake_provider.mdx new file mode 100644 index 00000000000..59362f4d318 --- /dev/null +++ b/docs/api/qiskit/1.0/providers_fake_provider.mdx @@ -0,0 +1,122 @@ +--- +title: fake_provider +description: API reference for qiskit.providers.fake_provider +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit.providers.fake_provider +--- + + + + + + + +# Fake Provider + + + +`qiskit.providers.fake_provider` + +## Overview + +The fake provider module in Qiskit contains fake (simulated) backend classes useful for testing the transpiler and other backend-facing functionality. + +## Example Usage + +Here is an example of using a simulated backend for transpilation and running. + +```python +from qiskit import QuantumCircuit, transpile +from qiskit.providers.fake_provider import GenericBackendV2 +from qiskit.visualization import plot_histogram + +# Generate a 5-qubit simulated backend +backend = GenericBackendV2(num_qubits=5) + +# 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 backend +job = backend.run(transpiled_circuit) +counts = job.result().get_counts() +plot_histogram(counts) +``` + +![../\_images/providers\_fake\_provider-1\_00.png](/images/api/qiskit/1.0/providers_fake_provider-1_00.png) + +![../\_images/providers\_fake\_provider-1\_01.png](/images/api/qiskit/1.0/providers_fake_provider-1_01.png) + +![../\_images/providers\_fake\_provider-1\_02.png](/images/api/qiskit/1.0/providers_fake_provider-1_02.png) + +## V2 Simulated Backends + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------ | +| [`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. | + +## V1 Fake Backends (Legacy interface) + +| | | +| ---------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------ | +| [`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. | +| [`Fake5QV1`](qiskit.providers.fake_provider.Fake5QV1 "qiskit.providers.fake_provider.Fake5QV1")() | A fake backend with the following characteristics: | +| [`Fake20QV1`](qiskit.providers.fake_provider.Fake20QV1 "qiskit.providers.fake_provider.Fake20QV1")() | A fake backend with the following characteristics: | +| [`Fake7QPulseV1`](qiskit.providers.fake_provider.Fake7QPulseV1 "qiskit.providers.fake_provider.Fake7QPulseV1")() | A fake **pulse** backend with the following characteristics: | +| [`Fake27QPulseV1`](qiskit.providers.fake_provider.Fake27QPulseV1 "qiskit.providers.fake_provider.Fake27QPulseV1")() | A fake **pulse** backend with the following characteristics: | +| [`Fake127QPulseV1`](qiskit.providers.fake_provider.Fake127QPulseV1 "qiskit.providers.fake_provider.Fake127QPulseV1")() | A fake **pulse** backend with the following characteristics: | + +## Fake Backend Base Classes + +The V1 fake backends are based on a set of base classes: + +### FakeBackend + + + 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 + + +### FakeQasmBackend + + + 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 + + +### FakePulseBackend + + + 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/1.0/providers_models.mdx b/docs/api/qiskit/1.0/providers_models.mdx new file mode 100644 index 00000000000..d707ddeb624 --- /dev/null +++ b/docs/api/qiskit/1.0/providers_models.mdx @@ -0,0 +1,39 @@ +--- +title: models +description: API reference for qiskit.providers.models +in_page_toc_min_heading_level: 2 +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/1.0/pulse.mdx b/docs/api/qiskit/1.0/pulse.mdx new file mode 100644 index 00000000000..da2f31f4bca --- /dev/null +++ b/docs/api/qiskit/1.0/pulse.mdx @@ -0,0 +1,2062 @@ +--- +title: pulse +description: API reference for qiskit.pulse +in_page_toc_min_heading_level: 2 +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. | +| [`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: + +### Instruction + + + 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/stdtypes.html#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. A user can 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. | + + + +### 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: + +### Channel + + + 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"). + +#### AlignmentKind + + + 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 + + + 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/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 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 + + + 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\[ScheduleComponent]*) – Collection of schedules to be aligned together + * **inst\_map** ([*InstructionScheduleMap*](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.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/stdtypes.html#list "(in Python v3.12)")\[[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule")] + + +#### block\_to\_schedule + + + 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 + + + Optimization pass to replace identical pulses. + + **Parameters** + + **schedules** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*qiskit.pulse.schedule.Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")*]*) – Schedules to compress. + + **Returns** + + Compressed schedules. + + **Return type** + + [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[qiskit.pulse.schedule.Schedule](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")] + + +#### flatten + + + 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 + + + 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") *|*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.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") | [ScheduleBlock](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") + + +#### pad + + + 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 to pad. + * **channels** (*Iterable\[chans.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*](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type")*\[*[*instructions.Instruction*](#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.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") + + +#### remove\_directives + + + 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 + + + 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 + + + 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** + + rx.PyDAG + + + + +### Composite transform + +A sequence of transformations to generate a target code. + +#### target\_qobj\_transform + + + 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-1.png](/images/api/qiskit/1.0/pulse-1.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 pulse + +d0 = pulse.DriveChannel(0) + +with pulse.build() as pulse_prog: + pulse.play(pulse.Constant(100, 1.0), d0) + +pulse_prog.draw() +``` + +![../\_images/pulse-2.png](/images/api/qiskit/1.0/pulse-2.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 transpiled and executed like a normal Qiskit schedule using `backend.run(transpile(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 +from math import pi +from qiskit.compiler import schedule +from qiskit.circuit import QuantumCircuit + +from qiskit import pulse +from qiskit.providers.fake_provider import GenericBackendV2 + +backend = GenericBackendV2(num_qubits=5, calibrate_instructions=True) + +d2 = pulse.DriveChannel(2) + +qc = QuantumCircuit(2) +# Hadamard +qc.rz(pi/2, 0) +qc.sx(0) +qc.rz(pi/2, 0) + +qc.cx(0, 1) + +bell_sched = schedule(qc, backend) + +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_sched) + pulse.play(pulse.Constant(bell_sched.duration, 0.02), d2) + pulse.barrier(0, 1, 2) + registers = pulse.measure_all() + +decoupled_bell_prep_and_measure.draw() +``` + +![../\_images/pulse-3.png](/images/api/qiskit/1.0/pulse-3.png) + +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.compiler import schedule + +from qiskit import pulse, QuantumCircuit +from qiskit.pulse import library +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() + +qc = QuantumCircuit(2, 2) +qc.cx(0, 1) + +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 schedule for a quantum circuit thereby inserting into + # the pulse schedule. + qc = QuantumCircuit(2, 2) + qc.cx(0, 1) + qc_sched = schedule(qc, backend) + pulse.call(qc_sched) + + + # 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) +``` + +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 + + + 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)) + ``` + + **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.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.AlignmentKind") *| None*) – Default scheduling alignment for builder. One of `left`, `right`, `sequential` or an alignment context. + + **Returns** + + A new builder context which has the active builder initialized. + + **Return type** + + ContextManager\[[ScheduleBlock](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock")] + + +### Channels + +Methods to return the correct channels for the respective qubit indices. + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import GenericBackendV2 + +backend = GenericBackendV2(num_qubits=2, calibrate_instructions=True) + +with pulse.build(backend) as drive_sched: + d0 = pulse.drive_channel(0) + print(d0) +``` + +```python +DriveChannel(0) +``` + +#### acquire\_channel + + + 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 + + + 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/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 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/stdtypes.html#list "(in Python v3.12)")\[[qiskit.pulse.channels.ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + + +#### drive\_channel + + + 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 + + + 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 GenericBackendV2 + +backend = GenericBackendV2(num_qubits=2, calibrate_instructions=True) + +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-4.png](/images/api/qiskit/1.0/pulse-4.png) + +#### acquire + + + 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)") *| chans.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** (*Unpack\[\_MetaDataType]*) – 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 + + + 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.call(backend.defaults.instruction_schedule_map.get('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.call(backend.defaults.instruction_schedule_map.get('x', (1,))) + ``` + + + Requires the active builder context to have a backend set if qubits are barriered on. + + + **Parameters** + + * **channels\_or\_qubits** (*chans.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 + + + 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` 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` instruction. + + + **Examples** + + 1. Calling a schedule block (recommended) + + ```python + from qiskit import circuit, pulse + from qiskit.providers.fake_provider import GenericBackendV2 + + backend = GenericBackendV2(num_qubits=5, calibrate_instructions=True) + + 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. + + **Parameters** + + * **target** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *|*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.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/stdtypes.html#dict "(in Python v3.12)")*\[ParameterValueType, ParameterValueType] | 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** (*ParameterValueType*) – 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 + + + 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** (*chans.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 + + + 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** (*library.Pulse | np.ndarray*) – Pulse to play. + * **channel** (*chans.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 + + + 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 + + + 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** (*chans.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 + + + 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** (*chans.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 + + + 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** (*chans.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 + + + 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** (*chans.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 + + + 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-5.png](/images/api/qiskit/1.0/pulse-5.png) + +#### align\_equispaced + + + 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-6.png](/images/api/qiskit/1.0/pulse-6.png) + + **Parameters** + + **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")) – Duration of this context. This should be larger than the schedule duration. + + **Yields** + + None + + **Return type** + + Generator\[None, None, None] + + **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 + + + 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-7.png](/images/api/qiskit/1.0/pulse-7.png) + + **Parameters** + + * **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")) – Duration of context. This should be larger than the schedule duration. + * **func** (*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)")*]*) – 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** + + Generator\[None, None, None] + + **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 + + + 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** + + [*Generator*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Generator "(in Python v3.12)")\[None, None, None] + + +#### align\_right + + + 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** + + [*Generator*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Generator "(in Python v3.12)")\[None, None, None] + + +#### align\_sequential + + + 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** + + [*Generator*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Generator "(in Python v3.12)")\[None, None, None] + + +#### frequency\_offset + + + 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** + + [*Generator*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Generator "(in Python v3.12)")\[None, None, None] + + +#### phase\_offset + + + 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** + + [*Generator*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Generator "(in Python v3.12)")\[None, None, None] + + +### Macros + +Macros help you add more complex functionality to your pulse program. + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import GenericBackendV2 + +backend = GenericBackendV2(num_qubits=2, calibrate_instructions=True) + +with pulse.build(backend) as measure_sched: + mem_slot = pulse.measure(0) + print(mem_slot) +``` + +```python +MemorySlot(0) +``` + +#### measure + + + 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/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)")) – Physical qubit to measure. + * **registers** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[StorageLocation] | StorageLocation*) – 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/stdtypes.html#list "(in Python v3.12)")\[StorageLocation] | StorageLocation + + +#### measure\_all + + + 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/stdtypes.html#list "(in Python v3.12)")\[[qiskit.pulse.channels.MemorySlot](qiskit.pulse.channels.MemorySlot "qiskit.pulse.channels.MemorySlot")] + + +#### delay\_qubits + + + Insert delays on all 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)")) – 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 GenericBackendV2 + +backend = GenericBackendV2(num_qubits=2, calibrate_instructions=True) + +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 + + + 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. + + +#### num\_qubits + + + 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 + + + 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/stdtypes.html#set "(in Python v3.12)")\[[qiskit.pulse.channels.Channel](#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")] + + +#### samples\_to\_seconds + + + 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)") *| np.ndarray*) – 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)") | np.ndarray + + +#### seconds\_to\_samples + + + 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)") *| np.ndarray*) – 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)") | np.ndarray + + +## 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 + + + Errors raised by the pulse module. + + Set the error message. + + +### BackendNotSet + + + Raised if the builder context does not have a backend. + + Set the error message. + + +### NoActiveBuilder + + + Raised if no builder context is active. + + Set the error message. + + +### UnassignedDurationError + + + Raised if instruction duration is unassigned. + + Set the error message. + + +### UnassignedReferenceError + + + Raised if subroutine is unassigned. + + Set the error message. + + diff --git a/docs/api/qiskit/1.0/qasm2.mdx b/docs/api/qiskit/1.0/qasm2.mdx new file mode 100644 index 00000000000..dea008cc504 --- /dev/null +++ b/docs/api/qiskit/1.0/qasm2.mdx @@ -0,0 +1,512 @@ +--- +title: qasm2 +description: API reference for qiskit.qasm2 +in_page_toc_min_heading_level: 2 +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 + + + 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 + + + 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: + +#### CustomInstruction + + + 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. + +#### 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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. + +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/1.0/qasm3.mdx b/docs/api/qiskit/1.0/qasm3.mdx new file mode 100644 index 00000000000..337a021d279 --- /dev/null +++ b/docs/api/qiskit/1.0/qasm3.mdx @@ -0,0 +1,405 @@ +--- +title: qasm3 +description: API reference for qiskit.qasm3 +in_page_toc_min_heading_level: 2 +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 + + + 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 + + + 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. + +### Exporter + + + 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 + + + Convert the circuit to OpenQASM 3, dumping the result to a file or text stream. + + + #### dumps + + + 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 + + + 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: + +#### ExperimentalFeatures + + + 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 + + + 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). + + These have the output format: + + ```python + switch (i) { + case 0: + case 1: + x $0; + break; + + case 2: { + z $0; + } + break; + + default: { + cx $0, $1; + } + break; + } + ``` + + This differs from the syntax of the `switch` statement as stabilized. If this flag is not passed, then the parser will instead output using the stabilized syntax, which would render the same example above as: + + ```python + switch (i) { + case 0, 1 { + x $0; + } + case 2 { + z $0; + } + default { + cx $0, $1; + } + } + ``` + + + +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 with the `qasm3-import` extra, such as by: + + ```python + pip install qiskit[qasm3-import] + ``` + + We expect that this functionality will eventually be merged into Qiskit, and no longer require an optional import, but we do not yet have a timeline for this. + + +### load + + + 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 + + + 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 + + + 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/1.0/qasm3-1.png) + +### Experimental import interface + +The import functions given above rely on the ANTLR-based reference parser from the OpenQASM project itself, which is more intended as a language reference than a performant parser. You need to have the extension `qiskit-qasm3-import` installed to use it. + +Qiskit is developing a native parser, written in Rust, which is available as part of the core Qiskit package. This parser is still in its early experimental stages, so is missing features and its interface is changing and expanding, but it is typically orders of magnitude more performant for the subset of OpenQASM 3 it currently supports, and its internals produce better error diagnostics on parsing failures. + +You can use the experimental interface immediately, with similar functions to the main interface above: + +#### load\_experimental + + + Load an OpenQASM 3 program from a source file into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + + + This native version of the OpenQASM 3 importer is currently experimental. It is typically much faster than [`load()`](#qiskit.qasm3.load "qiskit.qasm3.load"), but has a reduced supported feature set, which will expand over time. + + + **Parameters** + + * **pathlike\_or\_filelike** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*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)")) – the program source. This can either be given as a filepath, or an open text stream object. If the stream is already opened it is consumed in Python space, whereas filenames are opened and consumed in Rust space; there might be slightly different performance characteristics, depending on your system and how the streams are buffered by default. + * **custom\_gates** (*Iterable\[*[*CustomGate*](#qiskit.qasm3.CustomGate "qiskit.qasm3.CustomGate")*]*) – Python constructors to use for particular named gates. If not supplied, Qiskit will use its own standard-library constructors for gates defined in the OpenQASM 3.0 standard-library file `stdgates.inc`. + * **include\_path** (*Iterable\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – the path to search when resolving `include` statements. If not given, Qiskit will arrange for this to point to a location containing `stdgates.inc` only. Paths are tried in the sequence order. + + **Returns** + + the constructed circuit object. + + **Return type** + + [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + **Raises** + + **.QASM3ImporterError** – if an error occurred during parsing or semantic analysis. In the case of a parsing error, most of the error messages are printed to the terminal and formatted, for better legibility. + + +#### loads\_experimental + + + Load an OpenQASM 3 program from a string into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + + + This native version of the OpenQASM 3 importer is currently experimental. It is typically much faster than [`loads()`](#qiskit.qasm3.loads "qiskit.qasm3.loads"), but has a reduced supported feature set, which will expand over time. + + + **Parameters** + + * **source** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the program source in a Python string. + * **custom\_gates** (*Iterable\[*[*CustomGate*](#qiskit.qasm3.CustomGate "qiskit.qasm3.CustomGate")*]*) – Python constructors to use for particular named gates. If not supplied, Qiskit will use its own standard-library constructors for gates defined in the OpenQASM 3.0 standard-library file `stdgates.inc`. + * **include\_path** (*Iterable\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – the path to search when resolving `include` statements. If not given, Qiskit will arrange for this to point to a location containing `stdgates.inc` only. Paths are tried in the sequence order. + + **Returns** + + the constructed circuit object. + + **Return type** + + [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + **Raises** + + **.QASM3ImporterError** – if an error occurred during parsing or semantic analysis. In the case of a parsing error, most of the error messages are printed to the terminal and formatted, for better legibility. + + +These two functions are both experimental, meaning they issue an [`ExperimentalWarning`](exceptions#qiskit.exceptions.ExperimentalWarning "qiskit.exceptions.ExperimentalWarning") on usage, and their interfaces may be subject to change within the Qiskit 1.x release series. In particular, the native parser may be promoted to be the default version of [`load()`](#qiskit.qasm3.load "qiskit.qasm3.load") and [`loads()`](#qiskit.qasm3.loads "qiskit.qasm3.loads"). If you are happy to accept the risk of using the experimental interface, you can disable the warning by doing: + +```python +import warnings +from qiskit.exceptions import ExperimentalWarning + +warnings.filterwarnings("ignore", category=ExperimentalWarning, module="qiskit.qasm3") +``` + +These two functions allow for specifying include paths as an iterable of paths, and for specifying custom Python constructors to use for particular gates. These custom constructors are specified by using the [`CustomGate`](#qiskit.qasm3.CustomGate "qiskit.qasm3.CustomGate") object: + +#### CustomGate + + + Information received from Python space about how to construct a Python-space object to represent a given gate that might be declared. + + +In `custom_gates` is not given, Qiskit will attempt to use its standard-library gate objects for the gates defined in OpenQASM 3 standard library file `stdgates.inc`. This sequence of gates is available on this module, if you wish to build on top of it: + +**qiskit.qasm3.STDGATES\_INC\_GATES** + +A tuple of [`CustomGate`](#qiskit.qasm3.CustomGate "qiskit.qasm3.CustomGate") objects specifying the Qiskit constructors to use for the `stdgates.inc` include file. + diff --git a/docs/api/qiskit/1.0/qiskit.assembler.RunConfig.mdx b/docs/api/qiskit/1.0/qiskit.assembler.RunConfig.mdx new file mode 100644 index 00000000000..80be62fb55d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.assembler.RunConfig.mdx @@ -0,0 +1,100 @@ +--- +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 + + + 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 + + + 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 + + + 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/qiskit.circuit.AncillaQubit.mdx b/docs/api/qiskit/1.0/qiskit.circuit.AncillaQubit.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.AncillaQubit.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.AncillaQubit.mdx diff --git a/docs/api/qiskit/qiskit.circuit.AncillaRegister.mdx b/docs/api/qiskit/1.0/qiskit.circuit.AncillaRegister.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.AncillaRegister.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.AncillaRegister.mdx diff --git a/docs/api/qiskit/1.0/qiskit.circuit.AnnotatedOperation.mdx b/docs/api/qiskit/1.0/qiskit.circuit.AnnotatedOperation.mdx new file mode 100644 index 00000000000..1222acdd120 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.AnnotatedOperation.mdx @@ -0,0 +1,117 @@ +--- +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 + + + 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")) – base operation being modified + * **modifiers** (*Union\[Modifier, List\[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 + + ### control + + + Return the controlled version of itself. + + Implemented as an annotated operation, see [`AnnotatedOperation`](#qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **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*) – ignored (used for consistency with other control methods) + * **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`. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – ignored (used for consistency with other control methods) + + **Returns** + + Controlled version of the given operation. + + **Return type** + + [AnnotatedOperation](#qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") + + + ### copy + + + Return a copy of the [`AnnotatedOperation`](#qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **Return type** + + [*AnnotatedOperation*](#qiskit.circuit.AnnotatedOperation "qiskit.circuit.annotated_operation.AnnotatedOperation") + + + ### inverse + + + Return the inverse version of itself. + + Implemented as an annotated operation, see [`AnnotatedOperation`](#qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – ignored (used for consistency with other inverse methods) + + **Returns** + + Inverse version of the given operation. + + + ### to\_matrix + + + Return a matrix representation (allowing to construct Operator). + + + diff --git a/docs/api/qiskit/qiskit.circuit.Bit.mdx b/docs/api/qiskit/1.0/qiskit.circuit.Bit.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.Bit.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.Bit.mdx diff --git a/docs/api/qiskit/1.0/qiskit.circuit.BreakLoopOp.mdx b/docs/api/qiskit/1.0/qiskit.circuit.BreakLoopOp.mdx new file mode 100644 index 00000000000..b2082657e18 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.BreakLoopOp.mdx @@ -0,0 +1,307 @@ +--- +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 + + + 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 a decomposition of the instruction to the SessionEquivalenceLibrary. + + + ### assemble + + + Assemble a QasmQobjInstruction + + + ### broadcast\_arguments + + + 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 + + + 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 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 + + + Invert this instruction. + + If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. + + If annotated is True, the inverse instruction is implemented as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"), and corresponds to the given instruction annotated with the “inverse modifier”. + + Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) In particular, they can choose how to handle the argument `annotated` which may include ignoring it and always returning a concrete gate class if the inverse is defined as a standard gate. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if set to True the output inverse gate will be returned as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **Returns** + + The inverse operation. + + **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 + + + Return True .IFF. instruction is parameterized else False + + + ### repeat + + + 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 + + + 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 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 + + + 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 + + + Instruction parameters has no validation or normalization. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.CircuitInstruction.mdx b/docs/api/qiskit/1.0/qiskit.circuit.CircuitInstruction.mdx new file mode 100644 index 00000000000..909fe6e68cf --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.CircuitInstruction.mdx @@ -0,0 +1,78 @@ +--- +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 + + + 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 + + ### clbits + + + A sequence of the classical bits that this operation reads from or writes to. + + + ### operation + + + The logical operation that this instruction represents an execution of. + + + ### qubits + + + A sequence of the qubits that the operation is applied to. + + + ## Methods + + ### copy + + + Returns a shallow copy. + + **Returns** + + The shallow copy. + + **Return type** + + [CircuitInstruction](#qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") + + + ### replace + + + Creates a shallow copy with the given fields replaced. + + **Returns** + + A new instance with the given fields replaced. + + **Return type** + + [CircuitInstruction](#qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") + + + diff --git a/docs/api/qiskit/qiskit.circuit.ClassicalRegister.mdx b/docs/api/qiskit/1.0/qiskit.circuit.ClassicalRegister.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.ClassicalRegister.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.ClassicalRegister.mdx diff --git a/docs/api/qiskit/qiskit.circuit.Clbit.mdx b/docs/api/qiskit/1.0/qiskit.circuit.Clbit.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.Clbit.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.Clbit.mdx diff --git a/docs/api/qiskit/qiskit.circuit.CommutationChecker.mdx b/docs/api/qiskit/1.0/qiskit.circuit.CommutationChecker.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.CommutationChecker.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.CommutationChecker.mdx diff --git a/docs/api/qiskit/1.0/qiskit.circuit.ContinueLoopOp.mdx b/docs/api/qiskit/1.0/qiskit.circuit.ContinueLoopOp.mdx new file mode 100644 index 00000000000..546c8a18304 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.ContinueLoopOp.mdx @@ -0,0 +1,311 @@ +--- +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 + + + 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 a decomposition of the instruction to the SessionEquivalenceLibrary. + + + ### assemble + + + Assemble a QasmQobjInstruction + + + ### broadcast\_arguments + + + 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 + + + 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 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 + + + Invert this instruction. + + If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. + + If annotated is True, the inverse instruction is implemented as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"), and corresponds to the given instruction annotated with the “inverse modifier”. + + Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) In particular, they can choose how to handle the argument `annotated` which may include ignoring it and always returning a concrete gate class if the inverse is defined as a standard gate. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if set to True the output inverse gate will be returned as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **Returns** + + The inverse operation. + + **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 + + + Return True .IFF. instruction is parameterized else False + + + ### repeat + + + 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 + + + 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 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 + + + 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 + + + Instruction parameters has no validation or normalization. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.ControlFlowOp.mdx b/docs/api/qiskit/1.0/qiskit.circuit.ControlFlowOp.mdx new file mode 100644 index 00000000000..26fba208aac --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.ControlFlowOp.mdx @@ -0,0 +1,313 @@ +--- +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 + + + 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 a decomposition of the instruction to the SessionEquivalenceLibrary. + + + ### assemble + + + Assemble a QasmQobjInstruction + + + ### broadcast\_arguments + + + 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 + + + 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 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 + + + Invert this instruction. + + If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. + + If annotated is True, the inverse instruction is implemented as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"), and corresponds to the given instruction annotated with the “inverse modifier”. + + Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) In particular, they can choose how to handle the argument `annotated` which may include ignoring it and always returning a concrete gate class if the inverse is defined as a standard gate. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if set to True the output inverse gate will be returned as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **Returns** + + The inverse operation. + + **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 + + + Return True .IFF. instruction is parameterized else False + + + ### repeat + + + 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 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.ControlFlowOp") + + + ### 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 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 + + + 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 + + + Instruction parameters has no validation or normalization. + + + diff --git a/docs/api/qiskit/qiskit.circuit.ControlModifier.mdx b/docs/api/qiskit/1.0/qiskit.circuit.ControlModifier.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.ControlModifier.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.ControlModifier.mdx diff --git a/docs/api/qiskit/1.0/qiskit.circuit.ControlledGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.ControlledGate.mdx new file mode 100644 index 00000000000..04e27bf3e1d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.ControlledGate.mdx @@ -0,0 +1,448 @@ +--- +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 + + + 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/1.0/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/1.0/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 a decomposition of the instruction to the SessionEquivalenceLibrary. + + + ### assemble + + + Assemble a QasmQobjInstruction + + + ### broadcast\_arguments + + + 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 + + + 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 + + + Return the controlled version of itself. + + Implemented either as a controlled gate (ref. [`ControlledGate`](#qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). + + **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. Ignored if implemented as an annotated operation. + * **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`. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + Controlled version of the given operation. + + **Raises** + + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – unrecognized mode or invalid ctrl\_state + + + ### copy + + + 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 + + + Invert this gate by calling inverse on the base gate. + + **Return type** + + ControlledGate’ | ‘AnnotatedOperation + + + ### is\_parameterized + + + Return True .IFF. instruction is parameterized else False + + + ### power + + + 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 + + + ### repeat + + + 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 + + + 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 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 + + + 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 + + + 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 + + + Gate parameters should be int, float, or ParameterExpression + + + diff --git a/docs/api/qiskit/qiskit.circuit.Delay.mdx b/docs/api/qiskit/1.0/qiskit.circuit.Delay.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.Delay.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.Delay.mdx diff --git a/docs/api/qiskit/1.0/qiskit.circuit.EquivalenceLibrary.mdx b/docs/api/qiskit/1.0/qiskit.circuit.EquivalenceLibrary.mdx new file mode 100644 index 00000000000..b9fb4970ae7 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.EquivalenceLibrary.mdx @@ -0,0 +1,168 @@ +--- +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 + + + 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 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 + + + 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 + + + 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 + + + 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 + + + Return list of keys to key to node index map. + + **Returns** + + Keys to the key to node index map. + + **Return type** + + List + + + ### node\_index + + + 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 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/1.0/qiskit.circuit.ForLoopOp.mdx b/docs/api/qiskit/1.0/qiskit.circuit.ForLoopOp.mdx new file mode 100644 index 00000000000..b868ff7214c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.ForLoopOp.mdx @@ -0,0 +1,326 @@ +--- +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 + + + 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\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A collection of integers to loop over. + * **loop\_parameter** (*Union\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*, None]*) – The placeholder parameterizing `body` to which the values from `indexset` will be assigned. + * **body** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The loop body to be repeatedly executed. + * **label** (*Optional\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – 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 a decomposition of the instruction to the SessionEquivalenceLibrary. + + + ### assemble + + + Assemble a QasmQobjInstruction + + + ### broadcast\_arguments + + + 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 + + + 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 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 + + + Invert this instruction. + + If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. + + If annotated is True, the inverse instruction is implemented as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"), and corresponds to the given instruction annotated with the “inverse modifier”. + + Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) In particular, they can choose how to handle the argument `annotated` which may include ignoring it and always returning a concrete gate class if the inverse is defined as a standard gate. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if set to True the output inverse gate will be returned as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **Returns** + + The inverse operation. + + **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 + + + Return True .IFF. instruction is parameterized else False + + + ### repeat + + + 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 and return new instruction. :param blocks: Tuple of QuantumCircuits to replace in instruction. + + **Returns** + + New ControlFlowOp with replaced blocks. + + + ### 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 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 + + + 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 + + + Instruction parameters has no validation or normalization. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.Gate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.Gate.mdx new file mode 100644 index 00000000000..e1e1cb84808 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.Gate.mdx @@ -0,0 +1,382 @@ +--- +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 + + + 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 a decomposition of the instruction to the SessionEquivalenceLibrary. + + + ### assemble + + + Assemble a QasmQobjInstruction + + + ### broadcast\_arguments + + + 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 + + + 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 + + + Return the controlled version of itself. + + Implemented either as a controlled gate (ref. [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). + + **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. Ignored if implemented as an annotated operation. + * **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`. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + Controlled version of the given operation. + + **Raises** + + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – unrecognized mode or invalid ctrl\_state + + + ### copy + + + 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 + + + Invert this instruction. + + If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. + + If annotated is True, the inverse instruction is implemented as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"), and corresponds to the given instruction annotated with the “inverse modifier”. + + Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) In particular, they can choose how to handle the argument `annotated` which may include ignoring it and always returning a concrete gate class if the inverse is defined as a standard gate. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if set to True the output inverse gate will be returned as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **Returns** + + The inverse operation. + + **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 + + + Return True .IFF. instruction is parameterized else False + + + ### power + + + 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 + + + ### repeat + + + 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 + + + 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 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 + + + 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 + + + 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 + + + Gate parameters should be int, float, or ParameterExpression + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.IfElseOp.mdx b/docs/api/qiskit/1.0/qiskit.circuit.IfElseOp.mdx new file mode 100644 index 00000000000..dce3b36e293 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.IfElseOp.mdx @@ -0,0 +1,338 @@ +--- +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 + + + 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 a decomposition of the instruction to the SessionEquivalenceLibrary. + + + ### assemble + + + Assemble a QasmQobjInstruction + + + ### broadcast\_arguments + + + 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 + + + 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 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 + + + Invert this instruction. + + If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. + + If annotated is True, the inverse instruction is implemented as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"), and corresponds to the given instruction annotated with the “inverse modifier”. + + Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) In particular, they can choose how to handle the argument `annotated` which may include ignoring it and always returning a concrete gate class if the inverse is defined as a standard gate. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if set to True the output inverse gate will be returned as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **Returns** + + The inverse operation. + + **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 + + + Return True .IFF. instruction is parameterized else False + + + ### repeat + + + 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 and return new instruction. + + **Parameters** + + **blocks** (*Iterable\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.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.IfElseOp") + + + ### 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 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 + + + 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 + + + Instruction parameters has no validation or normalization. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.Instruction.mdx b/docs/api/qiskit/1.0/qiskit.circuit.Instruction.mdx new file mode 100644 index 00000000000..15d4fd6d403 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.Instruction.mdx @@ -0,0 +1,293 @@ +--- +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 + + + 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 a decomposition of the instruction to the SessionEquivalenceLibrary. + + + ### assemble + + + Assemble a QasmQobjInstruction + + + ### broadcast\_arguments + + + 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 + + + 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 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 + + + Invert this instruction. + + If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. + + If annotated is True, the inverse instruction is implemented as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"), and corresponds to the given instruction annotated with the “inverse modifier”. + + Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) In particular, they can choose how to handle the argument `annotated` which may include ignoring it and always returning a concrete gate class if the inverse is defined as a standard gate. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if set to True the output inverse gate will be returned as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **Returns** + + The inverse operation. + + **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 + + + Return True .IFF. instruction is parameterized else False + + + ### repeat + + + 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 + + + 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 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 + + + 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 + + + Instruction parameters has no validation or normalization. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.InstructionSet.mdx b/docs/api/qiskit/1.0/qiskit.circuit.InstructionSet.mdx new file mode 100644 index 00000000000..dd7be2b4836 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.InstructionSet.mdx @@ -0,0 +1,113 @@ +--- +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 + + + 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 an instruction and its context (where it is attached). + + + ### c\_if + + + 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/1.0/qiskit-circuit-InstructionSet-1.png) + + + ### inverse + + + Invert all instructions. + + + diff --git a/docs/api/qiskit/qiskit.circuit.InverseModifier.mdx b/docs/api/qiskit/1.0/qiskit.circuit.InverseModifier.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.InverseModifier.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.InverseModifier.mdx diff --git a/docs/api/qiskit/1.0/qiskit.circuit.Operation.mdx b/docs/api/qiskit/1.0/qiskit.circuit.Operation.mdx new file mode 100644 index 00000000000..021412012bd --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.Operation.mdx @@ -0,0 +1,53 @@ +--- +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 + + + 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/1.0/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/1.0/qiskit.circuit.Parameter.mdx b/docs/api/qiskit/1.0/qiskit.circuit.Parameter.mdx new file mode 100644 index 00000000000..d5fcf49f0a1 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.Parameter.mdx @@ -0,0 +1,252 @@ +--- +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 + + + 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/1.0/qiskit-circuit-Parameter-1_00.png) + + ![../\_images/qiskit-circuit-Parameter-1\_01.png](/images/api/qiskit/1.0/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. + + + ### uuid + + + Returns the [`UUID`](https://docs.python.org/3/library/uuid.html#uuid.UUID "(in Python v3.12)") of the [`Parameter`](#qiskit.circuit.Parameter "qiskit.circuit.Parameter"). + + In advanced use cases, this property can be passed to the [`Parameter`](#qiskit.circuit.Parameter "qiskit.circuit.Parameter") constructor to produce an instance that compares equal to another instance. + + + ## Methods + + ### abs + + + Absolute of a ParameterExpression + + + ### arccos + + + Arccos of a ParameterExpression + + + ### arcsin + + + Arcsin of a ParameterExpression + + + ### arctan + + + Arctan of a ParameterExpression + + + ### assign + + + 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 + + + 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 + + + Return the conjugate. + + **Return type** + + [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") + + + ### cos + + + Cosine of a ParameterExpression + + + ### exp + + + Exponential of a ParameterExpression + + + ### gradient + + + 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 + + + Return whether the expression is real + + + ### log + + + Logarithm of a ParameterExpression + + + ### numeric + + + Return a Python number representing this object, using the most restrictive of [`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)") and [`complex`](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") that is valid for this object. + + In general, an [`int`](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") is only returned if the expression only involved symbolic integers. If floating-point values were used during the evaluation, the return value will be a [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") regardless of whether the represented value is an integer. This is because floating-point values “infect” symbolic computations by their inexact nature, and symbolic libraries will use inexact floating-point semantics not exact real-number semantics when they are involved. If you want to assert that all floating-point calculations *were* carried out at infinite precision (i.e. [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") could represent every intermediate value exactly), you can use [`float.is_integer()`](https://docs.python.org/3/library/stdtypes.html#float.is_integer "(in Python v3.12)") to check if the return float represents an integer and cast it using [`int`](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") if so. This would be an unusual pattern; typically one requires this by only ever using explicitly [`Rational`](https://docs.python.org/3/library/numbers.html#numbers.Rational "(in Python v3.12)") objects while working with symbolic expressions. + + This is more reliable and performant than using [`is_real()`](#qiskit.circuit.Parameter.is_real "qiskit.circuit.Parameter.is_real") followed by calling [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") or [`complex`](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)"), as in some cases [`is_real()`](#qiskit.circuit.Parameter.is_real "qiskit.circuit.Parameter.is_real") needs to force a floating-point evaluation to determine an accurate result to work around bugs in the upstream symbolic libraries. + + **Returns** + + A Python number representing the object. + + **Raises** + + [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – if there are unbound parameters. + + **Return type** + + [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)") + + + ### sign + + + Sign of a ParameterExpression + + + ### sin + + + Sine of a ParameterExpression + + + ### subs + + + Substitute self with the corresponding parameter in `parameter_map`. + + + ### 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 + + + Tangent of a ParameterExpression + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.ParameterExpression.mdx b/docs/api/qiskit/1.0/qiskit.circuit.ParameterExpression.mdx new file mode 100644 index 00000000000..7b1534a6e4e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.ParameterExpression.mdx @@ -0,0 +1,236 @@ +--- +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 + + + 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 + + + Absolute of a ParameterExpression + + + ### arccos + + + Arccos of a ParameterExpression + + + ### arcsin + + + Arcsin of a ParameterExpression + + + ### arctan + + + Arctan of a ParameterExpression + + + ### assign + + + 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 + + + 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 + + + Return the conjugate. + + **Return type** + + [*ParameterExpression*](#qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") + + + ### cos + + + Cosine of a ParameterExpression + + + ### exp + + + Exponential of a ParameterExpression + + + ### gradient + + + 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 + + + Return whether the expression is real + + + ### log + + + Logarithm of a ParameterExpression + + + ### numeric + + + Return a Python number representing this object, using the most restrictive of [`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)") and [`complex`](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") that is valid for this object. + + In general, an [`int`](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") is only returned if the expression only involved symbolic integers. If floating-point values were used during the evaluation, the return value will be a [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") regardless of whether the represented value is an integer. This is because floating-point values “infect” symbolic computations by their inexact nature, and symbolic libraries will use inexact floating-point semantics not exact real-number semantics when they are involved. If you want to assert that all floating-point calculations *were* carried out at infinite precision (i.e. [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") could represent every intermediate value exactly), you can use [`float.is_integer()`](https://docs.python.org/3/library/stdtypes.html#float.is_integer "(in Python v3.12)") to check if the return float represents an integer and cast it using [`int`](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") if so. This would be an unusual pattern; typically one requires this by only ever using explicitly [`Rational`](https://docs.python.org/3/library/numbers.html#numbers.Rational "(in Python v3.12)") objects while working with symbolic expressions. + + This is more reliable and performant than using [`is_real()`](#qiskit.circuit.ParameterExpression.is_real "qiskit.circuit.ParameterExpression.is_real") followed by calling [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") or [`complex`](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)"), as in some cases [`is_real()`](#qiskit.circuit.ParameterExpression.is_real "qiskit.circuit.ParameterExpression.is_real") needs to force a floating-point evaluation to determine an accurate result to work around bugs in the upstream symbolic libraries. + + **Returns** + + A Python number representing the object. + + **Raises** + + [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – if there are unbound parameters. + + **Return type** + + [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)") + + + ### sign + + + Sign of a ParameterExpression + + + ### sin + + + Sine of a ParameterExpression + + + ### subs + + + 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 + + + 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 + + + Tangent of a ParameterExpression + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.ParameterVector.mdx b/docs/api/qiskit/1.0/qiskit.circuit.ParameterVector.mdx new file mode 100644 index 00000000000..db52e422500 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.ParameterVector.mdx @@ -0,0 +1,46 @@ +--- +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 + + + 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 + + + Returns first index of value. + + + ### resize + + + 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/qiskit.circuit.PowerModifier.mdx b/docs/api/qiskit/1.0/qiskit.circuit.PowerModifier.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.PowerModifier.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.PowerModifier.mdx diff --git a/docs/api/qiskit/1.0/qiskit.circuit.QuantumCircuit.mdx b/docs/api/qiskit/1.0/qiskit.circuit.QuantumCircuit.mdx new file mode 100644 index 00000000000..f7279b1bc72 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.QuantumCircuit.mdx @@ -0,0 +1,3189 @@ +--- +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 + + + 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/1.0/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/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + ## Methods + + ### add\_bits + + + Add Bits to the circuit. + + + ### add\_calibration + + + 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 registers. + + + ### append + + + 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 to new parameters or values. + + If `parameters` is passed as a dictionary, the keys should 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. + + + When `parameters` is given as a mapping, it is permissible to have keys that are strings of the parameter names; these will be looked up using [`get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter"). You can also have keys that are [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") instances, and in this case, the dictionary value should be a sequence of values of the same length as the vector. + + If you use either of these cases, you must leave the setting `flat_input=False`; changing this to `True` enables the fast path, where all keys must be [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances. + + + **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, or string keys, which will be converted to [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances using [`get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter"). + * **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/1.0/qiskit-circuit-QuantumCircuit-3_00.png) + + ![../\_images/qiskit-circuit-QuantumCircuit-3\_01.png](/images/api/qiskit/1.0/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/1.0/qiskit-circuit-QuantumCircuit-4_00.png) + + ![../\_images/qiskit-circuit-QuantumCircuit-4\_01.png](/images/api/qiskit/1.0/qiskit-circuit-QuantumCircuit-4_01.png) + + + ### barrier + + + 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") + + + ### 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 + + + Best effort to cast value to type. Otherwise, returns the value. + + **Return type** + + *S* | *T* + + + ### cbit\_argument\_conversion + + + 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 + + + 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 + + + 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 + + + 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 all instructions in self. + + Clearing the circuits will keep the metadata and calibrations. + + + ### 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 + + + Return the prefix to use for auto naming. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### compose + + + 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 + + + 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 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`. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **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 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 + + + 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 each operation kind in the circuit. + + **Returns** + + a breakdown of how many operations of each kind, sorted by amount. + + **Return type** + + OrderedDict + + + ### cp + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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. + + + ### draw + + + 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)") *| None*) – 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)") *| None*) – 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)") *| None*) – File path to save image to. Defaults to `None` (result not saved in a file). + + * **style** ([*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)") *| None*) – + + Style name, file name of style JSON file, or a dictionary specifying the style. + + * The supported style names are `"iqp"` (default), `"iqp-dark"`, `"clifford"`, `"textbook"` and `"bw"`. + * If given a JSON file, e.g. `my_style.json` or `my_style` (the `.json` extension may be omitted), this function attempts to load the style dictionary from that location. Note, that the JSON file must completely specify the visualization specifications. The file is searched for in `qiskit/visualization/circuit/styles`, the current working directory, and the location specified in `~/.qiskit/settings.conf`. + * If a dictionary, every entry overrides the default configuration. If the `"name"` key is given, the default configuration is given by that style. For example, `{"name": "textbook", "subfontsize": 5}` loads the `"texbook"` style and sets the subfontsize (e.g. the gate angles) to `5`. + * If `None` the default style `"iqp"` is used or, if given, the default style specified in `~/.qiskit/settings.conf`. + + * **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)") *| None*) – 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** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – 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** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – `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)") *| None*) – 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** (*Any | None*) – Only used by the mpl backend. An optional `matplotlib.axes.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)")) – Adds $|0\rangle$ in the beginning of the qubit wires and $0$ to classical wires. Default is `False`. + + * **cregbundle** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If set to `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)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – 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)")) – 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` (if `output='text'`)** + + A drawing that can be printed as ascii art. + + * **`matplotlib.figure.Figure` (if `output='mpl'`)** + + A matplotlib figure object for the circuit diagram. + + * **`PIL.Image` (if `output='latex`’)** + + An in-memory representation of the image of the circuit diagram. + + * **`str` (if `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 + qc = QuantumCircuit(1, 1) + qc.h(0) + qc.measure(0, 0) + qc.draw(output='mpl', style={'backgroundcolor': '#EEEEEE'}) + ``` + + ![../\_images/qiskit-circuit-QuantumCircuit-5.png](/images/api/qiskit/1.0/qiskit-circuit-QuantumCircuit-5.png) + + + ### ecr + + + 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 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 + + + 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. + + + ### from\_instructions + + + 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 + + + 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 + + + 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 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)")) + + + ### get\_parameter + + + Retrieve a compile-time parameter that is accessible in this circuit scope by name. + + **Parameters** + + * **name** – the name of the parameter to retrieve. + * **default** – if given, this value will be returned if the parameter is not present. If it is not given, a [`KeyError`](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") is raised instead. + + **Returns** + + The corresponding parameter. + + **Raises** + + [**KeyError**](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") – if no default is given, but the parameter does not exist in the circuit. + + **Examples** + + Retrieve a parameter by name from a circuit: + + ```python + from qiskit.circuit import QuantumCircuit, Parameter + + my_param = Parameter("my_param") + + # Create a parametrised circuit. + qc = QuantumCircuit(1) + qc.rx(my_param, 0) + + # We can use 'my_param' as a parameter, but let's say we've lost the Python object + # and need to retrieve it. + my_param_again = qc.get_parameter("my_param") + + assert my_param is my_param_again + ``` + + Get a variable from a circuit by name, returning some default if it is not present: + + ```python + assert qc.get_parameter("my_param", None) is my_param + assert qc.get_parameter("unknown_param", None) is None + ``` + + + ### h + + + 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") + + + ### has\_calibration\_for + + + 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\_parameter + + + Check whether a parameter object exists in this circuit. + + **Parameters** + + **name\_or\_param** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")) – the parameter, or name of a parameter to check. If this is a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") node, the parameter must be exactly the given one for this function to return `True`. + + **Returns** + + whether a matching parameter is assignable in this circuit. + + **Return type** + + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + **[`QuantumCircuit.get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter")** + + Retrieve the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instance from this circuit by name. + + + + ### has\_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)") + + + ### id + + + 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 + + + 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 + + + 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 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** ([*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$. + + * **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 + + + Invert (take adjoint of) this circuit. + + This is done by recursively inverting all gates. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the inverse gate can be implemented as an annotated gate. + + **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) ├───── + └───────────┘ + ``` + + + ### iswap + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + ### mcx + + + 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 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 qubits in a specific state. + + This class implements a state preparing unitary. Unlike [`initialize()`](#qiskit.circuit.QuantumCircuit.initialize "qiskit.circuit.QuantumCircuit.initialize") it does not reset the qubits first. + + **Parameters** + + * **state** ([*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$. + + * **qubits** (*Sequence\[QubitSpecifier] | None*) – Qubits to initialize. If `None` the initialization is applied to all qubits in the circuit. + + * **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. + + **Returns** + + A handle to the instruction that was just initialized + + **Return type** + + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + + **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 ├ + └───────────────────────────────────────────┘ + ``` + + + ### qbit\_argument\_conversion + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 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 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 + + + 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 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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)") + + + ### swap + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 `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](/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/1.0/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 + + + 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 + + + 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") + + + ### u + + + 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") + + + ### unitary + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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/qiskit.circuit.QuantumRegister.mdx b/docs/api/qiskit/1.0/qiskit.circuit.QuantumRegister.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.QuantumRegister.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.QuantumRegister.mdx diff --git a/docs/api/qiskit/qiskit.circuit.Qubit.mdx b/docs/api/qiskit/1.0/qiskit.circuit.Qubit.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.Qubit.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.Qubit.mdx diff --git a/docs/api/qiskit/qiskit.circuit.Register.mdx b/docs/api/qiskit/1.0/qiskit.circuit.Register.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.Register.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.Register.mdx diff --git a/docs/api/qiskit/1.0/qiskit.circuit.SwitchCaseOp.mdx b/docs/api/qiskit/1.0/qiskit.circuit.SwitchCaseOp.mdx new file mode 100644 index 00000000000..8c6d8c2ebce --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.SwitchCaseOp.mdx @@ -0,0 +1,348 @@ +--- +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 + + + 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 a decomposition of the instruction to the SessionEquivalenceLibrary. + + + ### assemble + + + Assemble a QasmQobjInstruction + + + ### broadcast\_arguments + + + 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 + + + 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 + + + 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 + + + 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\[Tuple\[Tuple, [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")]] + + + ### copy + + + 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 + + + Invert this instruction. + + If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. + + If annotated is True, the inverse instruction is implemented as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"), and corresponds to the given instruction annotated with the “inverse modifier”. + + Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) In particular, they can choose how to handle the argument `annotated` which may include ignoring it and always returning a concrete gate class if the inverse is defined as a standard gate. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if set to True the output inverse gate will be returned as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **Returns** + + The inverse operation. + + **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 + + + Return True .IFF. instruction is parameterized else False + + + ### repeat + + + 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 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.SwitchCaseOp") + + + ### 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 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 + + + 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 + + + Instruction parameters has no validation or normalization. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.WhileLoopOp.mdx b/docs/api/qiskit/1.0/qiskit.circuit.WhileLoopOp.mdx new file mode 100644 index 00000000000..68b37402a4b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.WhileLoopOp.mdx @@ -0,0 +1,327 @@ +--- +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 + + + 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 a decomposition of the instruction to the SessionEquivalenceLibrary. + + + ### assemble + + + Assemble a QasmQobjInstruction + + + ### broadcast\_arguments + + + 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 + + + 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 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 + + + Invert this instruction. + + If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. + + If annotated is True, the inverse instruction is implemented as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"), and corresponds to the given instruction annotated with the “inverse modifier”. + + Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) In particular, they can choose how to handle the argument `annotated` which may include ignoring it and always returning a concrete gate class if the inverse is defined as a standard gate. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if set to True the output inverse gate will be returned as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **Returns** + + The inverse operation. + + **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 + + + Return True .IFF. instruction is parameterized else False + + + ### repeat + + + 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 and return new instruction. :param blocks: Tuple of QuantumCircuits to replace in instruction. + + **Returns** + + New ControlFlowOp with replaced blocks. + + + ### 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 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 + + + 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 + + + Instruction parameters has no validation or normalization. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.BooleanExpression.mdx b/docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.BooleanExpression.mdx new file mode 100644 index 00000000000..d0e5e48ecc3 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.BooleanExpression.mdx @@ -0,0 +1,436 @@ +--- +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 + + + 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 a decomposition of the instruction to the SessionEquivalenceLibrary. + + + ### assemble + + + Assemble a QasmQobjInstruction + + + ### broadcast\_arguments + + + 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 + + + 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 + + + Return the controlled version of itself. + + Implemented either as a controlled gate (ref. [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). + + **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. Ignored if implemented as an annotated operation. + * **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`. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + Controlled version of the given operation. + + **Raises** + + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – unrecognized mode or invalid ctrl\_state + + + ### copy + + + 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 + + + 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 + + + Invert this instruction. + + If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. + + If annotated is True, the inverse instruction is implemented as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"), and corresponds to the given instruction annotated with the “inverse modifier”. + + Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) In particular, they can choose how to handle the argument `annotated` which may include ignoring it and always returning a concrete gate class if the inverse is defined as a standard gate. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if set to True the output inverse gate will be returned as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **Returns** + + The inverse operation. + + **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 + + + Return True .IFF. instruction is parameterized else False + + + ### power + + + 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 + + + ### repeat + + + 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 + + + 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 + + + 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 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 + + + 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 + + + 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 + + + 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 + + + Gate parameters should be int, float, or ParameterExpression + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.ClassicalFunction.mdx b/docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.ClassicalFunction.mdx new file mode 100644 index 00000000000..ac84450da2a --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.ClassicalFunction.mdx @@ -0,0 +1,491 @@ +--- +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 + + + 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 a decomposition of the instruction to the SessionEquivalenceLibrary. + + + ### assemble + + + Assemble a QasmQobjInstruction + + + ### broadcast\_arguments + + + 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 + + + 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 + + + Parses and creates the logical circuit + + + ### control + + + Return the controlled version of itself. + + Implemented either as a controlled gate (ref. [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). + + **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. Ignored if implemented as an annotated operation. + * **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`. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + Controlled version of the given operation. + + **Raises** + + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – unrecognized mode or invalid ctrl\_state + + + ### copy + + + 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 + + + Invert this instruction. + + If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. + + If annotated is True, the inverse instruction is implemented as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"), and corresponds to the given instruction annotated with the “inverse modifier”. + + Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) In particular, they can choose how to handle the argument `annotated` which may include ignoring it and always returning a concrete gate class if the inverse is defined as a standard gate. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if set to True the output inverse gate will be returned as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **Returns** + + The inverse operation. + + **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 + + + Return True .IFF. instruction is parameterized else False + + + ### power + + + 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 + + + ### repeat + + + 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 + + + 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 + + + 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 + + + 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 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 + + + 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 + + + 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 + + + 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 + + + Gate parameters should be int, float, or ParameterExpression + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.mdx b/docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.mdx new file mode 100644 index 00000000000..1aa89b64142 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.mdx @@ -0,0 +1,18 @@ +--- +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 + + + ClassicalFunction compiler type error. The classicalfunction function fails at type checking time. + + Set the error message. + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.mdx b/docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.mdx new file mode 100644 index 00000000000..85768085a57 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.mdx @@ -0,0 +1,18 @@ +--- +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 + + + ClassicalFunction compiler parse error. The classicalfunction function fails at parsing time. + + Set the error message. + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.AND.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.AND.mdx new file mode 100644 index 00000000000..92c93f42d46 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.AND.mdx @@ -0,0 +1,206 @@ +--- +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 + + + 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/1.0/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/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/qiskit.circuit.library.Barrier.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.Barrier.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.library.Barrier.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.library.Barrier.mdx diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.C3SXGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.C3SXGate.mdx new file mode 100644 index 00000000000..1a6bf169ea2 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.C3SXGate.mdx @@ -0,0 +1,162 @@ +--- +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 + + + 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** – An optional label for the gate \[Default: `None`] + * **ctrl\_state** – 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. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.C3XGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.C3XGate.mdx new file mode 100644 index 00000000000..371bab43a75 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.C3XGate.mdx @@ -0,0 +1,194 @@ +--- +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 + + + 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 + + + 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)") *| None*) – An optional label for the gate \[Default: `None`] + * **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*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Invert this gate. The C3X is its own inverse. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [C3XGate](#qiskit.circuit.library.C3XGate "qiskit.circuit.library.C3XGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.C4XGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.C4XGate.mdx new file mode 100644 index 00000000000..df07e170881 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.C4XGate.mdx @@ -0,0 +1,198 @@ +--- +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 + + + 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 + + + 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)") *| None*) – An optional label for the gate \[Default: `None`] + * **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*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Invert this gate. The C4X is its own inverse. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [C4XGate](#qiskit.circuit.library.C4XGate "qiskit.circuit.library.C4XGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CCXGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CCXGate.mdx new file mode 100644 index 00000000000..89bda3ac0c3 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CCXGate.mdx @@ -0,0 +1,250 @@ +--- +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 + + + 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()` 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 + + + 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)") *| None*) – An optional label for the gate \[Default: `None`] + * **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*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return an inverted CCX gate (also a CCX). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [CCXGate](#qiskit.circuit.library.CCXGate "qiskit.circuit.library.CCXGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CCZGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CCZGate.mdx new file mode 100644 index 00000000000..59c35044279 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CCZGate.mdx @@ -0,0 +1,204 @@ +--- +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 + + + 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 + + + Return inverted CCZ gate (itself). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [CCZGate](#qiskit.circuit.library.CCZGate "qiskit.circuit.library.CCZGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CDKMRippleCarryAdder.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CDKMRippleCarryAdder.mdx new file mode 100644 index 00000000000..93f5401964f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CDKMRippleCarryAdder.mdx @@ -0,0 +1,262 @@ +--- +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 + + + 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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CHGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CHGate.mdx new file mode 100644 index 00000000000..16970de4f11 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CHGate.mdx @@ -0,0 +1,207 @@ +--- +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 + + + 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 + + + Return inverted CH gate (itself). + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CPhaseGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CPhaseGate.mdx new file mode 100644 index 00000000000..564ee3d7b3c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CPhaseGate.mdx @@ -0,0 +1,215 @@ +--- +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 + + + 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 + + + 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)") *| None*) – An optional label for the gate \[Default: `None`] + * **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*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverted CPhase gate ($CPhase(\lambda)^{\dagger} = CPhase(-\lambda)$) + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CRXGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CRXGate.mdx new file mode 100644 index 00000000000..9d045b16ab2 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CRXGate.mdx @@ -0,0 +1,221 @@ +--- +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 + + + 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 + + + Return inverse CRX gate (i.e. with the negative rotation angle). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`CRXGate`](#qiskit.circuit.library.CRXGate "qiskit.circuit.library.CRXGate") with an inverted parameter value. + + **Returns** + + inverse gate. + + **Return type** + + [CRXGate](#qiskit.circuit.library.CRXGate "qiskit.circuit.library.CRXGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CRYGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CRYGate.mdx new file mode 100644 index 00000000000..9500b3d254b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CRYGate.mdx @@ -0,0 +1,223 @@ +--- +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 + + + 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 + + + Return inverse CRY gate (i.e. with the negative rotation angle) + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`CRYGate`](#qiskit.circuit.library.CRYGate "qiskit.circuit.library.CRYGate") with an inverted parameter value. + + **Returns** + + inverse gate. + + **Return type** + + [CRYGate](#qiskit.circuit.library.CRYGate "qiskit.circuit.library.CRYGate") + + . + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CRZGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CRZGate.mdx new file mode 100644 index 00000000000..a655f1d3fd6 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CRZGate.mdx @@ -0,0 +1,223 @@ +--- +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 + + + 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 + + + Return inverse CRZ gate (i.e. with the negative rotation angle). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – + + **when set to `True`, this is typically used to return an** + + [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`CRZGate`](#qiskit.circuit.library.CRZGate "qiskit.circuit.library.CRZGate") with an inverted parameter value. + + **Returns:** + + CRZGate: inverse gate. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CSGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CSGate.mdx new file mode 100644 index 00000000000..110f57c1a98 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CSGate.mdx @@ -0,0 +1,201 @@ +--- +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 + + + 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 + + + Return inverse of CSGate (CSdgGate). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`CSdgGate`](qiskit.circuit.library.CSdgGate "qiskit.circuit.library.CSdgGate"). + + **Returns** + + inverse of [`CSGate`](#qiskit.circuit.library.CSGate "qiskit.circuit.library.CSGate") + + **Return type** + + [CSdgGate](qiskit.circuit.library.CSdgGate "qiskit.circuit.library.CSdgGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CSXGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CSXGate.mdx new file mode 100644 index 00000000000..77c878380ec --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CSXGate.mdx @@ -0,0 +1,197 @@ +--- +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 + + + 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/1.0/qiskit.circuit.library.CSdgGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CSdgGate.mdx new file mode 100644 index 00000000000..f03e975a73f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CSdgGate.mdx @@ -0,0 +1,201 @@ +--- +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 + + + 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 + + + Return inverse of CSdgGate (CSGate). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`CSGate`](qiskit.circuit.library.CSGate "qiskit.circuit.library.CSGate"). + + **Returns** + + inverse of [`CSdgGate`](#qiskit.circuit.library.CSdgGate "qiskit.circuit.library.CSdgGate") + + **Return type** + + [CSGate](qiskit.circuit.library.CSGate "qiskit.circuit.library.CSGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CSwapGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CSwapGate.mdx new file mode 100644 index 00000000000..1a6ee9c5344 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CSwapGate.mdx @@ -0,0 +1,238 @@ +--- +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 + + + 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()` 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 + + + Return inverse CSwap gate (itself). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [CSwapGate](#qiskit.circuit.library.CSwapGate "qiskit.circuit.library.CSwapGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CU1Gate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CU1Gate.mdx new file mode 100644 index 00000000000..8bdc29d0710 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CU1Gate.mdx @@ -0,0 +1,219 @@ +--- +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 + + + 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 + + + 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)") *| None*) – An optional label for the gate \[Default: `None`] + * **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*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverted CU1 gate ($CU1(\lambda)^{\dagger} = CU1(-\lambda))$ + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`CU1Gate`](#qiskit.circuit.library.CU1Gate "qiskit.circuit.library.CU1Gate") with inverse parameter values. + + **Returns** + + inverse gate. + + **Return type** + + [CU1Gate](#qiskit.circuit.library.CU1Gate "qiskit.circuit.library.CU1Gate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CU3Gate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CU3Gate.mdx new file mode 100644 index 00000000000..2991e6d4e19 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CU3Gate.mdx @@ -0,0 +1,225 @@ +--- +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 + + + 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 + + + Return inverted CU3 gate. + + $CU3(\theta,\phi,\lambda)^{\dagger} =CU3(-\theta,-\phi,-\lambda))$ + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`CU3Gate`](#qiskit.circuit.library.CU3Gate "qiskit.circuit.library.CU3Gate") with inverse parameter values. + + **Returns** + + inverse gate. + + **Return type** + + [CU3Gate](#qiskit.circuit.library.CU3Gate "qiskit.circuit.library.CU3Gate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CUGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CUGate.mdx new file mode 100644 index 00000000000..6e2e7c412cc --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CUGate.mdx @@ -0,0 +1,215 @@ +--- +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 + + + 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 + + + Return inverted CU gate. + + $CU(\theta,\phi,\lambda,\gamma)^{\dagger} = CU(-\theta,-\phi,-\lambda,-\gamma))$ + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`CUGate`](#qiskit.circuit.library.CUGate "qiskit.circuit.library.CUGate") with inverse parameter values. + + **Returns** + + inverse gate. + + **Return type** + + [CUGate](#qiskit.circuit.library.CUGate "qiskit.circuit.library.CUGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CXGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CXGate.mdx new file mode 100644 index 00000000000..e897dee5b5c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CXGate.mdx @@ -0,0 +1,246 @@ +--- +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 + + + 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()` 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 + + + 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)") *| None*) – An optional label for the gate \[Default: `None`] + * **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*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverted CX gate (itself). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [CXGate](#qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CYGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CYGate.mdx new file mode 100644 index 00000000000..44a4f68ea33 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CYGate.mdx @@ -0,0 +1,217 @@ +--- +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 + + + 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 + + + Return inverted CY gate (itself). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [CYGate](#qiskit.circuit.library.CYGate "qiskit.circuit.library.CYGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.CZGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.CZGate.mdx new file mode 100644 index 00000000000..98ba6894483 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.CZGate.mdx @@ -0,0 +1,198 @@ +--- +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 + + + 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 + + + Return inverted CZ gate (itself). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [CZGate](#qiskit.circuit.library.CZGate "qiskit.circuit.library.CZGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.DCXGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.DCXGate.mdx new file mode 100644 index 00000000000..8a144b41125 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.DCXGate.mdx @@ -0,0 +1,139 @@ +--- +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 + + + 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/1.0/qiskit.circuit.library.Diagonal.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.Diagonal.mdx new file mode 100644 index 00000000000..0436ad346f5 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.Diagonal.mdx @@ -0,0 +1,234 @@ +--- +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 + + + 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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.DiagonalGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.DiagonalGate.mdx new file mode 100644 index 00000000000..c1af0918d61 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.DiagonalGate.mdx @@ -0,0 +1,131 @@ +--- +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 + + + 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 + + + Return the inverse of the diagonal gate. + + + ### validate\_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/1.0/qiskit.circuit.library.DraperQFTAdder.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.DraperQFTAdder.mdx new file mode 100644 index 00000000000..28b4c8e44dd --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.DraperQFTAdder.mdx @@ -0,0 +1,233 @@ +--- +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 + + + 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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.ECRGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.ECRGate.mdx new file mode 100644 index 00000000000..948207bf8ee --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.ECRGate.mdx @@ -0,0 +1,183 @@ +--- +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 + + + 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 + + + Return inverse ECR gate (itself). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [ECRGate](#qiskit.circuit.library.ECRGate "qiskit.circuit.library.ECRGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.EfficientSU2.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.EfficientSU2.mdx new file mode 100644 index 00000000000..02b85d1ab6c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.EfficientSU2.mdx @@ -0,0 +1,331 @@ +--- +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 + + + 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. + + + ### 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. + + + ### 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 + + + + ### 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 + + + + ### qregs + + + 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/1.0/qiskit.circuit.library.EvolvedOperatorAnsatz.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.EvolvedOperatorAnsatz.mdx new file mode 100644 index 00000000000..ffd7a4f5560 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.EvolvedOperatorAnsatz.mdx @@ -0,0 +1,305 @@ +--- +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 + + + Bases: [`NLocal`](qiskit.circuit.library.NLocal "qiskit.circuit.library.n_local.n_local.NLocal") + + The evolved operator ansatz. + + **Parameters** + + * **operators** (*BaseOperator |* [*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 |* [*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"). 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** + + [EvolutionSynthesis](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.EvolutionSynthesis") + + + ### 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. + + + ### 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 + + + + ### 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. + + + ### 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 + + + + ### qregs + + + 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/1.0/qiskit.circuit.library.ExactReciprocal.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.ExactReciprocal.mdx new file mode 100644 index 00000000000..578eb8ada17 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.ExactReciprocal.mdx @@ -0,0 +1,203 @@ +--- +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 + + + 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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.ExcitationPreserving.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.ExcitationPreserving.mdx new file mode 100644 index 00000000000..c0f28e463ab --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.ExcitationPreserving.mdx @@ -0,0 +1,350 @@ +--- +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 + + + 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. + + + ### 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. + + + ### 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 + + + + ### 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 + + + + ### qregs + + + 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/1.0/qiskit.circuit.library.FourierChecking.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.FourierChecking.mdx new file mode 100644 index 00000000000..7077be083fc --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.FourierChecking.mdx @@ -0,0 +1,217 @@ +--- +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 + + + 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/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.FunctionalPauliRotations.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.FunctionalPauliRotations.mdx new file mode 100644 index 00000000000..075132b3a62 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.FunctionalPauliRotations.mdx @@ -0,0 +1,168 @@ +--- +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 + + + 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 + + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + + + + ### qregs + + + 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/1.0/qiskit.circuit.library.GMS.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.GMS.mdx new file mode 100644 index 00000000000..7c95f9b3dbb --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.GMS.mdx @@ -0,0 +1,226 @@ +--- +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 + + + 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/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.GR.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.GR.mdx new file mode 100644 index 00000000000..2dd38316c1c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.GR.mdx @@ -0,0 +1,220 @@ +--- +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 + + + 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/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.GRX.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.GRX.mdx new file mode 100644 index 00000000000..d30e0f28710 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.GRX.mdx @@ -0,0 +1,219 @@ +--- +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 + + + 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/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.GRY.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.GRY.mdx new file mode 100644 index 00000000000..f6390f8efe5 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.GRY.mdx @@ -0,0 +1,219 @@ +--- +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 + + + 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/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.GRZ.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.GRZ.mdx new file mode 100644 index 00000000000..05d17945b65 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.GRZ.mdx @@ -0,0 +1,219 @@ +--- +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 + + + 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/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.GlobalPhaseGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.GlobalPhaseGate.mdx new file mode 100644 index 00000000000..3b9b9fafc21 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.GlobalPhaseGate.mdx @@ -0,0 +1,153 @@ +--- +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 + + + 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 + + + Return inverse GlobalPhaseGate gate. + + $\text{GlobalPhaseGate}(\lambda)^{\dagger} = \text{GlobalPhaseGate}(-\lambda)$ + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse is always another [`GlobalPhaseGate`](#qiskit.circuit.library.GlobalPhaseGate "qiskit.circuit.library.GlobalPhaseGate") with an inverted parameter value. + + **Returns** + + inverse gate. + + **Return type** + + [GlobalPhaseGate](#qiskit.circuit.library.GlobalPhaseGate "qiskit.circuit.library.GlobalPhaseGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.GraphState.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.GraphState.mdx new file mode 100644 index 00000000000..b67980c0df2 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.GraphState.mdx @@ -0,0 +1,224 @@ +--- +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 + + + 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/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.GroverOperator.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.GroverOperator.mdx new file mode 100644 index 00000000000..244af4ff931 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.GroverOperator.mdx @@ -0,0 +1,359 @@ +--- +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 + + + 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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### 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/1.0/qiskit.circuit.library.HGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.HGate.mdx new file mode 100644 index 00000000000..530145d5f2b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.HGate.mdx @@ -0,0 +1,180 @@ +--- +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 + + + 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 + + + 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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverted H gate (itself). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [HGate](#qiskit.circuit.library.HGate "qiskit.circuit.library.HGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.HRSCumulativeMultiplier.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.HRSCumulativeMultiplier.mdx new file mode 100644 index 00000000000..817b0587467 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.HRSCumulativeMultiplier.mdx @@ -0,0 +1,256 @@ +--- +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 + + + 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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.HamiltonianGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.HamiltonianGate.mdx new file mode 100644 index 00000000000..5b30b52a0c9 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.HamiltonianGate.mdx @@ -0,0 +1,157 @@ +--- +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 + + + 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 + + + Return the adjoint of the unitary. + + + ### conjugate + + + Return the conjugate of the Hamiltonian. + + + ### inverse + + + Return the adjoint of the unitary. + + + ### transpose + + + Return the transpose of the Hamiltonian. + + + ### validate\_parameter + + + Hamiltonian parameter has to be an ndarray, operator or float. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.HiddenLinearFunction.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.HiddenLinearFunction.mdx new file mode 100644 index 00000000000..fe26e07d6bd --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.HiddenLinearFunction.mdx @@ -0,0 +1,226 @@ +--- +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 + + + 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/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.IGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.IGate.mdx new file mode 100644 index 00000000000..f1a108eba4d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.IGate.mdx @@ -0,0 +1,164 @@ +--- +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 + + + 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()` 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 + + + Returne the inverse gate (itself). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [IGate](#qiskit.circuit.library.IGate "qiskit.circuit.library.IGate") + + . + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.IQP.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.IQP.mdx new file mode 100644 index 00000000000..7c593bec50d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.IQP.mdx @@ -0,0 +1,214 @@ +--- +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 + + + 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/1.0/qiskit-circuit-library-IQP-1.png) + + **Expanded Circuit:** + + > ![../\_images/qiskit-circuit-library-IQP-2.png](/images/api/qiskit/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.Initialize.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.Initialize.mdx new file mode 100644 index 00000000000..e99512fe31f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.Initialize.mdx @@ -0,0 +1,164 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.circuit.library.InnerProduct.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.InnerProduct.mdx new file mode 100644 index 00000000000..3a4d748321b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.InnerProduct.mdx @@ -0,0 +1,225 @@ +--- +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 + + + 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/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.IntegerComparator.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.IntegerComparator.mdx new file mode 100644 index 00000000000..5ddc4247be8 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.IntegerComparator.mdx @@ -0,0 +1,175 @@ +--- +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 + + + 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 + + + + ### 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. + + + ### instances + + + + ### 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 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 + + + + ### qregs + + + 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/1.0/qiskit.circuit.library.Isometry.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.Isometry.mdx new file mode 100644 index 00000000000..7490f159007 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.Isometry.mdx @@ -0,0 +1,168 @@ +--- +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 + + + 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 + + + Return the adjoint of the unitary. + + + ### inverse + + + Invert this instruction. + + If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. + + If annotated is True, the inverse instruction is implemented as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"), and corresponds to the given instruction annotated with the “inverse modifier”. + + Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) In particular, they can choose how to handle the argument `annotated` which may include ignoring it and always returning a concrete gate class if the inverse is defined as a standard gate. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if set to True the output inverse gate will be returned as [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **Returns** + + The inverse operation. + + **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 + + + Isometry parameter has to be an ndarray. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.LinearAmplitudeFunction.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.LinearAmplitudeFunction.mdx new file mode 100644 index 00000000000..da618c621a1 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.LinearAmplitudeFunction.mdx @@ -0,0 +1,260 @@ +--- +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 + + + 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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + ## Methods + + ### post\_processing + + + 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/1.0/qiskit.circuit.library.LinearFunction.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.LinearFunction.mdx new file mode 100644 index 00000000000..01329e53942 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.LinearFunction.mdx @@ -0,0 +1,235 @@ +--- +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 + + + 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 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 + + + Return string representation of the linear function viewed as a linear transformation. + + + ### 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 + + + Return string representation of the linear function viewed as a matrix with 0/1 entries. + + + ### 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 + + + 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 + + + Parameter validation + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.LinearPauliRotations.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.LinearPauliRotations.mdx new file mode 100644 index 00000000000..9a1a146f2e1 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.LinearPauliRotations.mdx @@ -0,0 +1,215 @@ +--- +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 + + + 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 + + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + + + + ### qregs + + + 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/1.0/qiskit.circuit.library.MCMT.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.MCMT.mdx new file mode 100644 index 00000000000..70592a0d5dd --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.MCMT.mdx @@ -0,0 +1,238 @@ +--- +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 + + + 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")*,* [*circuit.Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*,* [*circuit.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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + ## Methods + + ### control + + + Return the controlled version of the MCMT circuit. + + + ### inverse + + + Return the inverse MCMT circuit, which is itself. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.MCMTVChain.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.MCMTVChain.mdx new file mode 100644 index 00000000000..92212e0e5ee --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.MCMTVChain.mdx @@ -0,0 +1,256 @@ +--- +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 + + + 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/1.0/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")*,* [*circuit.Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*,* [*circuit.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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + ## Methods + + ### inverse + + + Return the inverse MCMT circuit, which is itself. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.MCPhaseGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.MCPhaseGate.mdx new file mode 100644 index 00000000000..ed62fdf45c7 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.MCPhaseGate.mdx @@ -0,0 +1,201 @@ +--- +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 + + + 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 + + + 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)") *| None*) – An optional label for the gate \[Default: `None`] + * **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*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverted MCU1 gate ($MCU1(\lambda)^{\dagger} = MCU1(-\lambda)$) + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.MCXGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.MCXGate.mdx new file mode 100644 index 00000000000..9f6b1968aca --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.MCXGate.mdx @@ -0,0 +1,212 @@ +--- +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 + + + 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 + + + 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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### get\_num\_ancilla\_qubits + + + 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 + + + Invert this gate. The MCX is its own inverse. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [MCXGate](#qiskit.circuit.library.MCXGate "qiskit.circuit.library.MCXGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.MCXGrayCode.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.MCXGrayCode.mdx new file mode 100644 index 00000000000..d60cd5612df --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.MCXGrayCode.mdx @@ -0,0 +1,179 @@ +--- +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 + + + 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 + + + Invert this gate. The MCX is its own inverse. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [MCXGrayCode](#qiskit.circuit.library.MCXGrayCode "qiskit.circuit.library.MCXGrayCode") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.MCXRecursive.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.MCXRecursive.mdx new file mode 100644 index 00000000000..51c52b51953 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.MCXRecursive.mdx @@ -0,0 +1,185 @@ +--- +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 + + + 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 + + + Get the number of required ancilla qubits. + + + ### inverse + + + Invert this gate. The MCX is its own inverse. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [MCXRecursive](#qiskit.circuit.library.MCXRecursive "qiskit.circuit.library.MCXRecursive") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.MCXVChain.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.MCXVChain.mdx new file mode 100644 index 00000000000..ae64b3c32bf --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.MCXVChain.mdx @@ -0,0 +1,183 @@ +--- +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 + + + 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 + + + Get the number of required ancilla qubits. + + + ### inverse + + + Invert this gate. The MCX is its own inverse. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [MCXVChain](#qiskit.circuit.library.MCXVChain "qiskit.circuit.library.MCXVChain") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.MSGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.MSGate.mdx new file mode 100644 index 00000000000..e2c15b5bdb4 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.MSGate.mdx @@ -0,0 +1,121 @@ +--- +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 + + + 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/qiskit.circuit.library.Measure.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.Measure.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.library.Measure.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.library.Measure.mdx diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.NLocal.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.NLocal.mdx new file mode 100644 index 00000000000..e2d9715529f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.NLocal.mdx @@ -0,0 +1,432 @@ +--- +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 + + + 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. + + + ### 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. + + + ### 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 + + + + ### 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 + + + + ### qregs + + + 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 + + + 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 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 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 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 + + + 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/1.0/qiskit.circuit.library.OR.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.OR.mdx new file mode 100644 index 00000000000..d128ebcda44 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.OR.mdx @@ -0,0 +1,206 @@ +--- +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 + + + 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/1.0/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/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.PauliEvolutionGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.PauliEvolutionGate.mdx new file mode 100644 index 00000000000..6c078089e88 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.PauliEvolutionGate.mdx @@ -0,0 +1,190 @@ +--- +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 + + + 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.quantum_info import SparsePauliOp + + X = SparsePauliOp("X") + Z = SparsePauliOp("Z") + + # 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") *|*[*SparsePauliOp*](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") *|*[*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 + + + 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/1.0/qiskit.circuit.library.PauliFeatureMap.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.PauliFeatureMap.mdx new file mode 100644 index 00000000000..dce247793ba --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.PauliFeatureMap.mdx @@ -0,0 +1,394 @@ +--- +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 + + + 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 + + + + ### 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. + + + ### 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 + + + + ### 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 + + + + ### qregs + + + 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 + + + Get the Pauli block for the feature map circuit. + + + ### pauli\_evolution + + + Get the evolution block for the given pauli string. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.PauliGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.PauliGate.mdx new file mode 100644 index 00000000000..de7d691ffd9 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.PauliGate.mdx @@ -0,0 +1,142 @@ +--- +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 + + + 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 + + + Return inverted pauli gate (itself). + + + ### validate\_parameter + + + Gate parameters should be int, float, or ParameterExpression + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.PauliTwoDesign.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.PauliTwoDesign.mdx new file mode 100644 index 00000000000..615e606437f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.PauliTwoDesign.mdx @@ -0,0 +1,309 @@ +--- +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 + + + 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/1.0/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. + + + ### 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. + + + ### 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 + + + + ### 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 + + + + ### qregs + + + 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/1.0/qiskit.circuit.library.Permutation.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.Permutation.mdx new file mode 100644 index 00000000000..9ec0ea999c4 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.Permutation.mdx @@ -0,0 +1,208 @@ +--- +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 + + + 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/1.0/qiskit-circuit-library-Permutation-1.png) + + **Expanded Circuit:** + + ![../\_images/qiskit-circuit-library-Permutation-2.png](/images/api/qiskit/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.PermutationGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.PermutationGate.mdx new file mode 100644 index 00000000000..06b80deb060 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.PermutationGate.mdx @@ -0,0 +1,151 @@ +--- +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 + + + 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/1.0/qiskit-circuit-library-PermutationGate-1.png) + + **Expanded Circuit:** + + ![../\_images/qiskit-circuit-library-PermutationGate-2.png](/images/api/qiskit/1.0/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 + + + Returns the inverse of the permutation. + + + ### validate\_parameter + + + Parameter validation. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.PhaseEstimation.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.PhaseEstimation.mdx new file mode 100644 index 00000000000..b3dc1540845 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.PhaseEstimation.mdx @@ -0,0 +1,225 @@ +--- +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 + + + 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/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.PhaseGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.PhaseGate.mdx new file mode 100644 index 00000000000..7930a99492a --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.PhaseGate.mdx @@ -0,0 +1,208 @@ +--- +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 + + + 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 + + + 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)") *| None*) – An optional label for the gate \[Default: `None`] + * **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*) – control state expressed as integer, string (e.g. `'110'`), or `None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverted Phase gate ($Phase(\lambda)^{\dagger} = Phase(-\lambda)$) + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always another `PGate` with an inverse parameter value. + + **Returns** + + inverse gate. + + **Return type** + + PGate + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.PhaseOracle.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.PhaseOracle.mdx new file mode 100644 index 00000000000..b116f8f4f05 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.PhaseOracle.mdx @@ -0,0 +1,258 @@ +--- +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 + + + 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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + ## Methods + + ### evaluate\_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 + + + 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/1.0/qiskit.circuit.library.PiecewiseChebyshev.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.PiecewiseChebyshev.mdx new file mode 100644 index 00000000000..b2867c19c96 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.PiecewiseChebyshev.mdx @@ -0,0 +1,221 @@ +--- +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 + + + 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/1.0/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. + + + ### 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. + + + ### instances + + + + ### 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 + + + + ### qregs + + + 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/1.0/qiskit.circuit.library.PiecewiseLinearPauliRotations.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.PiecewiseLinearPauliRotations.mdx new file mode 100644 index 00000000000..896cc19a495 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.PiecewiseLinearPauliRotations.mdx @@ -0,0 +1,256 @@ +--- +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 + + + 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 + + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + + + + ### qregs + + + 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 + + + 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/1.0/qiskit.circuit.library.PiecewisePolynomialPauliRotations.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.PiecewisePolynomialPauliRotations.mdx new file mode 100644 index 00000000000..7ae79bb96fc --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.PiecewisePolynomialPauliRotations.mdx @@ -0,0 +1,288 @@ +--- +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 + + + 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 + + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + + + + ### qregs + + + 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 + + + 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/1.0/qiskit.circuit.library.PolynomialPauliRotations.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.PolynomialPauliRotations.mdx new file mode 100644 index 00000000000..285dffa10a3 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.PolynomialPauliRotations.mdx @@ -0,0 +1,218 @@ +--- +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 + + + 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. + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + + + + ### qregs + + + 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/1.0/qiskit.circuit.library.QAOAAnsatz.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.QAOAAnsatz.mdx new file mode 100644 index 00000000000..42ed8bf6f42 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.QAOAAnsatz.mdx @@ -0,0 +1,325 @@ +--- +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 + + + Bases: [`EvolvedOperatorAnsatz`](qiskit.circuit.library.EvolvedOperatorAnsatz "qiskit.circuit.library.n_local.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, 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 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 + + + ### 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** + + [EvolutionSynthesis](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.EvolutionSynthesis") + + + ### 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. + + + ### 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 + + + + ### 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 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, [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 + + + + ### qregs + + + 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/1.0/qiskit.circuit.library.QFT.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.QFT.mdx new file mode 100644 index 00000000000..178ab2dd7a5 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.QFT.mdx @@ -0,0 +1,229 @@ +--- +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 + + + 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/1.0/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/1.0/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/1.0/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. + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### insert\_barriers + + + Whether barriers are inserted for better visualization or not. + + **Returns** + + True, if barriers are inserted, False if not. + + + ### instances + + + + ### 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 + + + + ### qregs + + + 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 + + + Invert this circuit. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the inverse gate can be implemented as an annotated gate. The value of this argument is ignored as the inverse of a QFT is an IQFT which is just another instance of [`QFT`](#qiskit.circuit.library.QFT "qiskit.circuit.library.QFT"). + + **Returns** + + The inverted circuit. + + **Return type** + + [*QFT*](#qiskit.circuit.library.QFT "qiskit.circuit.library.basis_change.qft.QFT") + + + ### 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/1.0/qiskit.circuit.library.QuadraticForm.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.QuadraticForm.mdx new file mode 100644 index 00000000000..ebc8e652be8 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.QuadraticForm.mdx @@ -0,0 +1,249 @@ +--- +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 + + + 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** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *| 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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + ## Methods + + ### required\_result\_qubits + + + 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/1.0/qiskit.circuit.library.QuantumVolume.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.QuantumVolume.mdx new file mode 100644 index 00000000000..59c80f28736 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.QuantumVolume.mdx @@ -0,0 +1,213 @@ +--- +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 + + + 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/1.0/qiskit-circuit-library-QuantumVolume-1.png) + + **Expanded Circuit:** + + ![../\_images/qiskit-circuit-library-QuantumVolume-2.png](/images/api/qiskit/1.0/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** ([*Generator*](https://numpy.org/doc/stable/reference/random/generator.html#numpy.random.Generator "(in NumPy v1.26)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| 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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.RC3XGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.RC3XGate.mdx new file mode 100644 index 00000000000..db45bef9169 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.RC3XGate.mdx @@ -0,0 +1,121 @@ +--- +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 + + + 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/1.0/qiskit.circuit.library.RCCXGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.RCCXGate.mdx new file mode 100644 index 00000000000..bc5db7fbb02 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.RCCXGate.mdx @@ -0,0 +1,121 @@ +--- +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 + + + 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/1.0/qiskit.circuit.library.RGQFTMultiplier.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.RGQFTMultiplier.mdx new file mode 100644 index 00000000000..1f9e1320017 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.RGQFTMultiplier.mdx @@ -0,0 +1,235 @@ +--- +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 + + + 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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.RGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.RGate.mdx new file mode 100644 index 00000000000..690ebc7366f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.RGate.mdx @@ -0,0 +1,163 @@ +--- +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 + + + 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 + + + Invert this gate as: $r(θ, φ)^dagger = r(-θ, φ)$ + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`RGate`](#qiskit.circuit.library.RGate "qiskit.circuit.library.RGate") with an inverted parameter value. + + **Returns** + + inverse gate. + + **Return type** + + [RGate](#qiskit.circuit.library.RGate "qiskit.circuit.library.RGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.RVGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.RVGate.mdx new file mode 100644 index 00000000000..2e4714154da --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.RVGate.mdx @@ -0,0 +1,163 @@ +--- +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 + + + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + + Rotation around arbitrary rotation axis $\vec{v}$ where $\|\vec{v}\|_2$ 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}{\frac{\|\vec{v}\|_2}{2}} +R(\vec{v}) = e^{-i \vec{v}\cdot\vec{\sigma} / 2} = +\begin{pmatrix} +\cos\left(\rotationangle\right) +-i \frac{v_z}{\|\vec{v}\|_2} \sin\left(\rotationangle\right) +& -(i \frac{v_x}{\|\vec{v}\|_2} ++ \frac{v_y}{\|\vec{v}\|_2}) \sin\left(\rotationangle\right) \\ +-(i \frac{v_x}{\|\vec{v}\|_2} +- \frac{v_y}{\|\vec{v}\|_2}) \sin\left(\rotationangle\right) +& \cos\left(\rotationangle\right) ++ i \frac{v_z}{\|\vec{v}\|_2} \sin\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 + + + Invert this gate. + + + ### to\_matrix + + + Return a numpy.array for the R(v) gate. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.RXGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.RXGate.mdx new file mode 100644 index 00000000000..3e1b31de5e5 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.RXGate.mdx @@ -0,0 +1,186 @@ +--- +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 + + + 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 + + + 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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverted RX gate. + + $RX(\lambda)^{\dagger} = RX(-\lambda)$ + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`RXGate`](#qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate") with an inverted parameter value. + + **Returns** + + inverse gate. + + **Return type** + + [RXGate](#qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.RXXGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.RXXGate.mdx new file mode 100644 index 00000000000..52ba90ce2f3 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.RXXGate.mdx @@ -0,0 +1,189 @@ +--- +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 + + + 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 + + + Return inverse RXX gate (i.e. with the negative rotation angle). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`RXXGate`](#qiskit.circuit.library.RXXGate "qiskit.circuit.library.RXXGate") with an inverted parameter value. + + **Returns** + + inverse gate. + + **Return type** + + [RXXGate](#qiskit.circuit.library.RXXGate "qiskit.circuit.library.RXXGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.RYGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.RYGate.mdx new file mode 100644 index 00000000000..074539986d2 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.RYGate.mdx @@ -0,0 +1,186 @@ +--- +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 + + + 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 + + + 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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverse RY gate. + + $RY(\lambda)^{\dagger} = RY(-\lambda)$ + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`RYGate`](#qiskit.circuit.library.RYGate "qiskit.circuit.library.RYGate") with an inverted parameter value. + + **Returns** + + inverse gate. + + **Return type** + + [RYGate](#qiskit.circuit.library.RYGate "qiskit.circuit.library.RYGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.RYYGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.RYYGate.mdx new file mode 100644 index 00000000000..82e61121d2c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.RYYGate.mdx @@ -0,0 +1,189 @@ +--- +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 + + + 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 + + + Return inverse RYY gate (i.e. with the negative rotation angle). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`RYYGate`](#qiskit.circuit.library.RYYGate "qiskit.circuit.library.RYYGate") with an inverted parameter value. + + **Returns** + + inverse gate. + + **Return type** + + [RYYGate](#qiskit.circuit.library.RYYGate "qiskit.circuit.library.RYYGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.RZGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.RZGate.mdx new file mode 100644 index 00000000000..7e892e1da0c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.RZGate.mdx @@ -0,0 +1,196 @@ +--- +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 + + + 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 + + + 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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverted RZ gate + + $RZ(\lambda)^{\dagger} = RZ(-\lambda)$ + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`RZGate`](#qiskit.circuit.library.RZGate "qiskit.circuit.library.RZGate") with an inverted parameter value. + + **Returns** + + inverse gate. + + **Return type** + + [RZGate](#qiskit.circuit.library.RZGate "qiskit.circuit.library.RZGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.RZXGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.RZXGate.mdx new file mode 100644 index 00000000000..b796bbad54e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.RZXGate.mdx @@ -0,0 +1,229 @@ +--- +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 + + + 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 + + + Return inverse RZX gate (i.e. with the negative rotation angle). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – + + **when set to `True`, this is typically used to return an** + + [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`RZXGate`](#qiskit.circuit.library.RZXGate "qiskit.circuit.library.RZXGate") with an inverted parameter value. + + **Returns:** + + RZXGate: inverse gate. + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.RZZGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.RZZGate.mdx new file mode 100644 index 00000000000..c008fa72ff8 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.RZZGate.mdx @@ -0,0 +1,201 @@ +--- +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 + + + 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 + + + Return inverse RZZ gate (i.e. with the negative rotation angle). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`RZZGate`](#qiskit.circuit.library.RZZGate "qiskit.circuit.library.RZZGate") with an inverted parameter value. + + **Returns** + + inverse gate. + + **Return type** + + [RZZGate](#qiskit.circuit.library.RZZGate "qiskit.circuit.library.RZZGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.RealAmplitudes.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.RealAmplitudes.mdx new file mode 100644 index 00000000000..7cfe3560879 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.RealAmplitudes.mdx @@ -0,0 +1,369 @@ +--- +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 + + + 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. + + + ### 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. + + + ### 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 + + + + ### 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 + + + + ### qregs + + + 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/qiskit.circuit.library.Reset.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.Reset.mdx similarity index 100% rename from docs/api/qiskit/qiskit.circuit.library.Reset.mdx rename to docs/api/qiskit/1.0/qiskit.circuit.library.Reset.mdx diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.SGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.SGate.mdx new file mode 100644 index 00000000000..209f5cab960 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.SGate.mdx @@ -0,0 +1,166 @@ +--- +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 + + + 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 + + + Return inverse of S (SdgGate). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate"). + + **Returns** + + inverse of [`SGate`](#qiskit.circuit.library.SGate "qiskit.circuit.library.SGate") + + **Return type** + + [SdgGate](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.SXGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.SXGate.mdx new file mode 100644 index 00000000000..af11ca417dc --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.SXGate.mdx @@ -0,0 +1,189 @@ +--- +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 + + + 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 + + + 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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [SingletonControlledGate](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + + + ### inverse + + + Return inverse SX gate (i.e. SXdg). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`SXdgGate`](qiskit.circuit.library.SXdgGate "qiskit.circuit.library.SXdgGate"). + + **Returns** + + inverse of [`SXGate`](#qiskit.circuit.library.SXGate "qiskit.circuit.library.SXGate"). + + **Return type** + + [SXdgGate](qiskit.circuit.library.SXdgGate "qiskit.circuit.library.SXdgGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.SXdgGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.SXdgGate.mdx new file mode 100644 index 00000000000..aeb6263c150 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.SXdgGate.mdx @@ -0,0 +1,156 @@ +--- +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 + + + 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 + + + Return inverse SXdg gate (i.e. SX). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`SXGate`](qiskit.circuit.library.SXGate "qiskit.circuit.library.SXGate"). + + **Returns** + + inverse of [`SXdgGate`](#qiskit.circuit.library.SXdgGate "qiskit.circuit.library.SXdgGate") + + **Return type** + + [SXGate](qiskit.circuit.library.SXGate "qiskit.circuit.library.SXGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.SdgGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.SdgGate.mdx new file mode 100644 index 00000000000..817b767d2f7 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.SdgGate.mdx @@ -0,0 +1,166 @@ +--- +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 + + + 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 + + + Return inverse of Sdg (SGate). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate"). + + **Returns** + + inverse of [`SdgGate`](#qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate") + + **Return type** + + [SGate](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.StatePreparation.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.StatePreparation.mdx new file mode 100644 index 00000000000..cf229907413 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.StatePreparation.mdx @@ -0,0 +1,203 @@ +--- +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 + + + 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 + + + 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 + + + Return inverted StatePreparation + + + ### validate\_parameter + + + StatePreparation instruction parameter can be str, int, float, and complex. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.SwapGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.SwapGate.mdx new file mode 100644 index 00000000000..b7d10d9eeb2 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.SwapGate.mdx @@ -0,0 +1,188 @@ +--- +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 + + + 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 + + + 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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverse Swap gate (itself). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [SwapGate](#qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.TGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.TGate.mdx new file mode 100644 index 00000000000..2743bc72de7 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.TGate.mdx @@ -0,0 +1,166 @@ +--- +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 + + + 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 + + + Return inverse T gate (i.e. Tdg). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`TdgGate`](qiskit.circuit.library.TdgGate "qiskit.circuit.library.TdgGate"). + + **Returns** + + inverse of [`TGate`](#qiskit.circuit.library.TGate "qiskit.circuit.library.TGate") + + **Return type** + + [TdgGate](qiskit.circuit.library.TdgGate "qiskit.circuit.library.TdgGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.TdgGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.TdgGate.mdx new file mode 100644 index 00000000000..196e9c13842 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.TdgGate.mdx @@ -0,0 +1,166 @@ +--- +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 + + + 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 + + + Return inverse Tdg gate (i.e. T). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`TGate`](qiskit.circuit.library.TGate "qiskit.circuit.library.TGate"). + + **Returns** + + inverse of [`TdgGate`](#qiskit.circuit.library.TdgGate "qiskit.circuit.library.TdgGate") + + **Return type** + + [TGate](qiskit.circuit.library.TGate "qiskit.circuit.library.TGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.TwoLocal.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.TwoLocal.mdx new file mode 100644 index 00000000000..057dfe392e9 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.TwoLocal.mdx @@ -0,0 +1,393 @@ +--- +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 + + + 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. + + + ### 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. + + + ### 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 + + + + ### 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 + + + + ### qregs + + + 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 + + + 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/1.0/qiskit.circuit.library.U1Gate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.U1Gate.mdx new file mode 100644 index 00000000000..3450710eb5e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.U1Gate.mdx @@ -0,0 +1,215 @@ +--- +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 + + + 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 + + + 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)") *| None*) – An optional label for the gate \[Default: `None`] + * **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*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverted U1 gate ($U1(\lambda)^{\dagger} = U1(-\lambda))$ + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`U1Gate`](#qiskit.circuit.library.U1Gate "qiskit.circuit.library.U1Gate") with inverse parameter values. + + **Returns** + + inverse gate. + + **Return type** + + [U1Gate](#qiskit.circuit.library.U1Gate "qiskit.circuit.library.U1Gate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.U2Gate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.U2Gate.mdx new file mode 100644 index 00000000000..48ca1bf4e0d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.U2Gate.mdx @@ -0,0 +1,195 @@ +--- +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 + + + 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 + + + Return inverted U2 gate. + + $U2(\phi, \lambda)^{\dagger} =U2(-\lambda-\pi, -\phi+\pi))$ + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`U2Gate`](#qiskit.circuit.library.U2Gate "qiskit.circuit.library.U2Gate") with inverse parameter values. + + **Returns** + + inverse gate. + + **Return type** + + [U2Gate](#qiskit.circuit.library.U2Gate "qiskit.circuit.library.U2Gate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.U3Gate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.U3Gate.mdx new file mode 100644 index 00000000000..a75a806b8d1 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.U3Gate.mdx @@ -0,0 +1,211 @@ +--- +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 + + + 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 + + + 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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverted U3 gate. + + $U3(\theta,\phi,\lambda)^{\dagger} =U3(-\theta,-\lambda,-\phi))$ + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`U3Gate`](#qiskit.circuit.library.U3Gate "qiskit.circuit.library.U3Gate") with inverse parameter values. + + **Returns** + + inverse gate. + + **Return type** + + [U3Gate](#qiskit.circuit.library.U3Gate "qiskit.circuit.library.U3Gate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.UCGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.UCGate.mdx new file mode 100644 index 00000000000..0c36d82547b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.UCGate.mdx @@ -0,0 +1,163 @@ +--- +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 + + + 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 + + + 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 + + + Uniformly controlled gate parameter has to be an ndarray. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.UCPauliRotGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.UCPauliRotGate.mdx new file mode 100644 index 00000000000..ea9814aa122 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.UCPauliRotGate.mdx @@ -0,0 +1,120 @@ +--- +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 + + + 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/1.0/qiskit.circuit.library.UCRXGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.UCRXGate.mdx new file mode 100644 index 00000000000..55446bc4e0e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.UCRXGate.mdx @@ -0,0 +1,119 @@ +--- +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 + + + 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/1.0/qiskit.circuit.library.UCRYGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.UCRYGate.mdx new file mode 100644 index 00000000000..465f6729c49 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.UCRYGate.mdx @@ -0,0 +1,119 @@ +--- +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 + + + 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/1.0/qiskit.circuit.library.UCRZGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.UCRZGate.mdx new file mode 100644 index 00000000000..de8d111541d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.UCRZGate.mdx @@ -0,0 +1,119 @@ +--- +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 + + + 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/1.0/qiskit.circuit.library.UGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.UGate.mdx new file mode 100644 index 00000000000..a6b4955c065 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.UGate.mdx @@ -0,0 +1,194 @@ +--- +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 + + + 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 + + + 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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverted U gate. + + $U(\theta,\phi,\lambda)^{\dagger} =U(-\theta,-\lambda,-\phi))$ + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`UGate`](#qiskit.circuit.library.UGate "qiskit.circuit.library.UGate") with inverse parameter values. + + **Returns** + + inverse gate. + + **Return type** + + [UGate](#qiskit.circuit.library.UGate "qiskit.circuit.library.UGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.UnitaryGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.UnitaryGate.mdx new file mode 100644 index 00000000000..aae20f1caaf --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.UnitaryGate.mdx @@ -0,0 +1,196 @@ +--- +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 + + + 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 + + + Return the adjoint of the unitary. + + + ### conjugate + + + Return the conjugate of the unitary. + + + ### control + + + 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** ([*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 bit string (e.g. `"1011"`). If `None`, use `2**num_ctrl_qubits - 1`. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + Controlled version of gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") | [AnnotatedOperation](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") + + + ### inverse + + + Return the adjoint of the unitary. + + + ### transpose + + + Return the transpose of the unitary. + + + ### validate\_parameter + + + Unitary gate parameter has to be an ndarray. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.UnitaryOverlap.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.UnitaryOverlap.mdx new file mode 100644 index 00000000000..dce005d6d91 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.UnitaryOverlap.mdx @@ -0,0 +1,235 @@ +--- +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 + + + 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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.VBERippleCarryAdder.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.VBERippleCarryAdder.mdx new file mode 100644 index 00000000000..a7de53fb7c9 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.VBERippleCarryAdder.mdx @@ -0,0 +1,234 @@ +--- +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 + + + 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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.WeightedAdder.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.WeightedAdder.mdx new file mode 100644 index 00000000000..329f2ebb523 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.WeightedAdder.mdx @@ -0,0 +1,231 @@ +--- +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 + + + 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 + + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + + + + ### qregs + + + 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/1.0/qiskit.circuit.library.XGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.XGate.mdx new file mode 100644 index 00000000000..b683fcfe6af --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.XGate.mdx @@ -0,0 +1,198 @@ +--- +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 + + + 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 + + + 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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverted X gate (itself). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [XGate](#qiskit.circuit.library.XGate "qiskit.circuit.library.XGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.XOR.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.XOR.mdx new file mode 100644 index 00000000000..3b28afecd21 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.XOR.mdx @@ -0,0 +1,208 @@ +--- +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 + + + 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/1.0/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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### qubits + + + Returns a list of quantum bits in the order that the registers were added. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.XXMinusYYGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.XXMinusYYGate.mdx new file mode 100644 index 00000000000..979893888fd --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.XXMinusYYGate.mdx @@ -0,0 +1,199 @@ +--- +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 + + + 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 gate. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`XXMinusYYGate`](#qiskit.circuit.library.XXMinusYYGate "qiskit.circuit.library.XXMinusYYGate") with inverse parameter values. + + **Returns** + + inverse gate. + + **Return type** + + [XXMinusYYGate](#qiskit.circuit.library.XXMinusYYGate "qiskit.circuit.library.XXMinusYYGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.XXPlusYYGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.XXPlusYYGate.mdx new file mode 100644 index 00000000000..208478c0c56 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.XXPlusYYGate.mdx @@ -0,0 +1,199 @@ +--- +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 + + + 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 + + + Return inverse XX+YY gate (i.e. with the negative rotation angle and same phase angle). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as the inverse of this gate is always a [`XXPlusYYGate`](#qiskit.circuit.library.XXPlusYYGate "qiskit.circuit.library.XXPlusYYGate") with inverse parameter values. + + **Returns** + + inverse gate. + + **Return type** + + [XXPlusYYGate](#qiskit.circuit.library.XXPlusYYGate "qiskit.circuit.library.XXPlusYYGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.YGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.YGate.mdx new file mode 100644 index 00000000000..32163acfe8b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.YGate.mdx @@ -0,0 +1,198 @@ +--- +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 + + + 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 + + + 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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverted Y gate ($Y^{\dagger} = Y$) + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [YGate](#qiskit.circuit.library.YGate "qiskit.circuit.library.YGate") + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.ZFeatureMap.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.ZFeatureMap.mdx new file mode 100644 index 00000000000..184c8bc68c2 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.ZFeatureMap.mdx @@ -0,0 +1,347 @@ +--- +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 + + + 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 + + + + ### 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. + + + ### 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 + + + + ### 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 + + + + ### qregs + + + 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/1.0/qiskit.circuit.library.ZGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.ZGate.mdx new file mode 100644 index 00000000000..2c8ff3bc333 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.ZGate.mdx @@ -0,0 +1,204 @@ +--- +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 + + + 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 + + + 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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **Returns** + + controlled version of this gate. + + **Return type** + + [ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + + + ### inverse + + + Return inverted Z gate (itself). + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to `True`, this is typically used to return an [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") with an inverse modifier set instead of a concrete [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). However, for this class this argument is ignored as this gate is self-inverse. + + **Returns** + + inverse gate (self-inverse). + + **Return type** + + [ZGate](#qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate") + + + ### power + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.circuit.library.ZZFeatureMap.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.ZZFeatureMap.mdx new file mode 100644 index 00000000000..9898678bdae --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.ZZFeatureMap.mdx @@ -0,0 +1,352 @@ +--- +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 + + + 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 + + + + ### 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. + + + ### 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 + + + + ### 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 + + + + ### qregs + + + 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/1.0/qiskit.circuit.library.iSwapGate.mdx b/docs/api/qiskit/1.0/qiskit.circuit.library.iSwapGate.mdx new file mode 100644 index 00000000000..11eb6835273 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.circuit.library.iSwapGate.mdx @@ -0,0 +1,176 @@ +--- +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 + + + 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 + + + Raise gate to a power. + + + diff --git a/docs/api/qiskit/1.0/qiskit.dagcircuit.DAGCircuit.mdx b/docs/api/qiskit/1.0/qiskit.dagcircuit.DAGCircuit.mdx new file mode 100644 index 00000000000..dff8b616711 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.dagcircuit.DAGCircuit.mdx @@ -0,0 +1,886 @@ +--- +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 + + + 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 + + + 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 individual clbit wires. + + + ### add\_creg + + + Add all wires in a classical register. + + + ### add\_qreg + + + Add all wires in a quantum register. + + + ### add\_qubits + + + Add individual qubit wires. + + + ### ancestors + + + Returns set of the ancestors of a node as DAGOpNodes and DAGInNodes. + + + ### apply\_operation\_back + + + 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 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 + + + 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 + + + Returns iterator of the predecessors of a node that are connected by a classical edge as DAGOpNodes and DAGInNodes. + + + ### classical\_successors + + + Returns iterator of the successors of a node that are connected by a classical edge as DAGOpNodes and DAGInNodes. + + + ### collect\_1q\_runs + + + Return a set of non-conditional runs of 1q “op” nodes. + + + ### collect\_2q\_runs + + + Return a set of non-conditional runs of 2q “op” nodes. + + + ### collect\_runs + + + 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 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 + + + 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 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 the occurrences of operation names on the longest path. + + Returns a dictionary of counts keyed on the operation name. + + + ### depth + + + 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 + + + Returns set of the descendants of a node as DAGOpNodes and DAGOutNodes. + + + ### draw + + + 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 + + + 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 + + + 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 + + + Return a list of op nodes in the first layer of this dag. + + + ### 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 + + + 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 + + + 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 + + + Checks if a second node is in the predecessors of node. + + + ### is\_successor + + + Checks if a second node is in the successors of node. + + + ### 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 + + + Returns the longest path in the dag as a list of DAGOpNodes, DAGInNodes, and DAGOutNodes. + + + ### multi\_qubit\_ops + + + Get list of 3+ qubit operations. Ignore directives like snapshot and barrier. + + + ### multigraph\_layers + + + Yield layers of the multigraph. + + + ### named\_nodes + + + Get the set of “op” nodes with the given name. + + + ### node + + + 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 + + + Iterator for node values. + + **Yields** + + *node* – the node. + + + ### nodes\_on\_wire + + + 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 + + + Return the total number of classical bits used by the circuit. + + + ### 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 + + + Compute how many components the circuit can decompose into. + + + ### op\_nodes + + + 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 + + + Returns iterator of the predecessors of a node as DAGOpNodes and DAGInNodes. + + + ### properties + + + Return a dictionary of circuit properties. + + + ### quantum\_causal\_cone + + + 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 + + + Returns iterator of the predecessors of a node that are connected by a quantum edge as DAGOpNodes and DAGInNodes. + + + ### quantum\_successors + + + 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 operation nodes with the given name. + + + ### remove\_ancestors\_of + + + Remove all of the ancestor operation nodes of node. + + + ### remove\_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 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 all of the descendant operation nodes of node. + + + ### remove\_nonancestors\_of + + + Remove all of the non-ancestors operation nodes of node. + + + ### remove\_nondescendants\_of + + + Remove all of the non-descendants operation nodes of node. + + + ### remove\_op\_node + + + Remove an operation node n. + + Add edges from predecessors to successors. + + + ### remove\_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 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 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 the operations in the `self` circuit. + + **Returns** + + the reversed dag. + + **Return type** + + [DAGCircuit](#qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + + + ### separable\_circuits + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 fulfill 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 + + + Returns iterator of the successors of a node as DAGOpNodes and DAGOutNodes. + + + ### swap\_nodes + + + 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 + + + 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 + + + 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 + + + Get list of 2 qubit operations. Ignore directives like snapshot and barrier. + + + ### 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/1.0/qiskit.dagcircuit.DAGDepNode.mdx b/docs/api/qiskit/1.0/qiskit.dagcircuit.DAGDepNode.mdx new file mode 100644 index 00000000000..a722b2b617f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.dagcircuit.DAGDepNode.mdx @@ -0,0 +1,111 @@ +--- +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 + + + 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 + + + Function to copy a DAGDepNode object. :returns: a copy of a DAGDepNode object. :rtype: DAGDepNode + + + ### semantic\_eq + + + 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/1.0/qiskit.dagcircuit.DAGDependency.mdx b/docs/api/qiskit/1.0/qiskit.dagcircuit.DAGDependency.mdx new file mode 100644 index 00000000000..2f8e9ddf5e4 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.dagcircuit.DAGDependency.mdx @@ -0,0 +1,344 @@ +--- +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 + + + 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 individual clbit wires. + + + ### add\_creg + + + Add clbits in a classical register. + + + ### add\_op\_node + + + 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 qubits in a quantum register. + + + ### add\_qubits + + + Add individual qubit wires. + + + ### copy + + + Function to copy a DAGDependency object. :returns: a copy of a DAGDependency object. :rtype: DAGDependency + + + ### depth + + + Return the circuit depth. :returns: the circuit depth :rtype: int + + + ### direct\_predecessors + + + 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 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 + + + 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 + + + Enumeration of all edges. + + **Returns** + + corresponding to the label. + + **Return type** + + List + + + ### get\_edges + + + 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 + + + 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 + + + **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 + + + **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 + + + 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 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 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 + + + Returns the number of gates in the circuit + + + ### successors + + + 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 + + + Returns the DAGDependency in retworkx format. + + + ### 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/1.0/qiskit.dagcircuit.DAGInNode.mdx b/docs/api/qiskit/1.0/qiskit.dagcircuit.DAGInNode.mdx new file mode 100644 index 00000000000..ef8b942b319 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.dagcircuit.DAGInNode.mdx @@ -0,0 +1,51 @@ +--- +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 + + + 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 + + + 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)"). + + **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/1.0/qiskit.dagcircuit.DAGNode.mdx b/docs/api/qiskit/1.0/qiskit.dagcircuit.DAGNode.mdx new file mode 100644 index 00000000000..9210f2fb34d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.dagcircuit.DAGNode.mdx @@ -0,0 +1,41 @@ +--- +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 + + + 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 + + + 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)"). + + **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/1.0/qiskit.dagcircuit.DAGOpNode.mdx b/docs/api/qiskit/1.0/qiskit.dagcircuit.DAGOpNode.mdx new file mode 100644 index 00000000000..2af56d7d273 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.dagcircuit.DAGOpNode.mdx @@ -0,0 +1,65 @@ +--- +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 + + + 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 + + + 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)"). + + **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/1.0/qiskit.dagcircuit.DAGOutNode.mdx b/docs/api/qiskit/1.0/qiskit.dagcircuit.DAGOutNode.mdx new file mode 100644 index 00000000000..23c372e389d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.dagcircuit.DAGOutNode.mdx @@ -0,0 +1,51 @@ +--- +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 + + + 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 + + + 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)"). + + **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/1.0/qiskit.passmanager.BaseController.mdx b/docs/api/qiskit/1.0/qiskit.passmanager.BaseController.mdx new file mode 100644 index 00000000000..4f4c4af3d83 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.passmanager.BaseController.mdx @@ -0,0 +1,67 @@ +--- +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 + + + 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 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 + + + 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/1.0/qiskit.passmanager.BasePassManager.mdx b/docs/api/qiskit/1.0/qiskit.passmanager.BasePassManager.mdx new file mode 100644 index 00000000000..7bee8f79277 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.passmanager.BasePassManager.mdx @@ -0,0 +1,131 @@ +--- +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 + + + 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 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 + + + 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 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 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'] + ... + ``` + + * **num\_processes** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of parallel processes to launch if parallel execution is enabled. This argument overrides `num_processes` in the user configuration file, and the `QISKIT_NUM_PROCS` environment variable. If set to `None` the system default or local user configuration will be used. + + * **kwargs** – Arbitrary arguments passed to the compiler frontend and backend. + + **Returns** + + The transformed program(s). + + **Return type** + + Any + + + ### 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/1.0/qiskit.passmanager.ConditionalController.mdx b/docs/api/qiskit/1.0/qiskit.passmanager.ConditionalController.mdx new file mode 100644 index 00000000000..acbdd5005a8 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.passmanager.ConditionalController.mdx @@ -0,0 +1,73 @@ +--- +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 + + + 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 + + ### execute + + + 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 + + + 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/1.0/qiskit.passmanager.DoWhileController.mdx b/docs/api/qiskit/1.0/qiskit.passmanager.DoWhileController.mdx new file mode 100644 index 00000000000..43928834483 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.passmanager.DoWhileController.mdx @@ -0,0 +1,75 @@ +--- +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 + + + 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 + + ### execute + + + 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 + + + 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/1.0/qiskit.passmanager.FlowControllerLinear.mdx b/docs/api/qiskit/1.0/qiskit.passmanager.FlowControllerLinear.mdx new file mode 100644 index 00000000000..17b9f6c04bd --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.passmanager.FlowControllerLinear.mdx @@ -0,0 +1,73 @@ +--- +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 + + + 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 + + ### execute + + + 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 + + + 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/1.0/qiskit.passmanager.GenericPass.mdx b/docs/api/qiskit/1.0/qiskit.passmanager.GenericPass.mdx new file mode 100644 index 00000000000..3f8924bc2b0 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.passmanager.GenericPass.mdx @@ -0,0 +1,87 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.passmanager.PassManagerState.mdx b/docs/api/qiskit/1.0/qiskit.passmanager.PassManagerState.mdx new file mode 100644 index 00000000000..a6eb9a5e81e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.passmanager.PassManagerState.mdx @@ -0,0 +1,34 @@ +--- +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 + + + 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 + + + Status of the current compilation workflow. + + + ### property\_set + + + Information about IR being optimized. + + + diff --git a/docs/api/qiskit/1.0/qiskit.passmanager.PropertySet.mdx b/docs/api/qiskit/1.0/qiskit.passmanager.PropertySet.mdx new file mode 100644 index 00000000000..33d4f3245a0 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.passmanager.PropertySet.mdx @@ -0,0 +1,78 @@ +--- +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 + + + Bases: [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + + A default dictionary-like object. + + ## Methods + + ### clear + + + + ### copy + + + + ### fromkeys + + + Create a new dictionary with keys from iterable and values set to value. + + + ### get + + + Return the value for key if key is in the dictionary, else default. + + + ### items + + + + ### keys + + + + ### pop + + + If key is not found, default is returned if given, otherwise KeyError is raised + + + ### 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 + + + 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 + + + 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 + + + + diff --git a/docs/api/qiskit/1.0/qiskit.passmanager.WorkflowStatus.mdx b/docs/api/qiskit/1.0/qiskit.passmanager.WorkflowStatus.mdx new file mode 100644 index 00000000000..969db6ac506 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.passmanager.WorkflowStatus.mdx @@ -0,0 +1,38 @@ +--- +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 + + + 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 + + + Current number of pass execution. + + + ### previous\_run + + + Status of the latest pass run. + + + ### completed\_passes + + + Passes already run that have not been invalidated. + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.BackendEstimator.mdx b/docs/api/qiskit/1.0/qiskit.primitives.BackendEstimator.mdx new file mode 100644 index 00000000000..d565cd1719d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.BackendEstimator.mdx @@ -0,0 +1,130 @@ +--- +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 + + + Bases: [`BaseEstimatorV1`](qiskit.primitives.BaseEstimatorV1 "qiskit.primitives.base.base_estimator.BaseEstimatorV1")\[[`PrimitiveJob`](qiskit.primitives.PrimitiveJob "qiskit.primitives.primitive_job.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` 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` API. It facilitates using backends that do not provide a native `BaseEstimator` implementation in places that work with `BaseEstimator`. However, if you’re using a provider that has a native implementation of `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 + + + ### options + + + Return options values for the estimator. + + **Returns** + + options + + + ### 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 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]. + ``` + + **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 |* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | BaseOperator |* [*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 values for the estimator. + + **Parameters** + + **\*\*fields** – The fields to update the options + + + ### set\_transpile\_options + + + Set the transpiler options for transpiler. :param \*\*fields: The fields to update the options + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.BackendSampler.mdx b/docs/api/qiskit/1.0/qiskit.primitives.BackendSampler.mdx new file mode 100644 index 00000000000..e73dcb81ad5 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.BackendSampler.mdx @@ -0,0 +1,125 @@ +--- +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 + + + Bases: [`BaseSamplerV1`](qiskit.primitives.BaseSamplerV1 "qiskit.primitives.base.base_sampler.BaseSamplerV1")\[[`PrimitiveJob`](qiskit.primitives.PrimitiveJob "qiskit.primitives.primitive_job.PrimitiveJob")\[[`SamplerResult`](qiskit.primitives.SamplerResult "qiskit.primitives.base.sampler_result.SamplerResult")]] + + A `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` implementation in places that work with `BaseSampler`. However, if you’re using a provider that has a native implementation of `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 + + + ### options + + + Return options values for the estimator. + + **Returns** + + options + + + ### 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 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 values for the estimator. + + **Parameters** + + **\*\*fields** – The fields to update the options + + + ### set\_transpile\_options + + + 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/1.0/qiskit.primitives.BaseEstimator.mdx b/docs/api/qiskit/1.0/qiskit.primitives.BaseEstimator.mdx new file mode 100644 index 00000000000..ebdc7ccb7df --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.BaseEstimator.mdx @@ -0,0 +1,14 @@ +--- +title: BaseEstimator +description: API reference for qiskit.primitives.BaseEstimator +in_page_toc_min_heading_level: 1 +python_api_type: attribute +python_api_name: qiskit.primitives.BaseEstimator +--- + +# BaseEstimator + + + alias of [`BaseEstimatorV1`](qiskit.primitives.BaseEstimatorV1 "qiskit.primitives.base.base_estimator.BaseEstimatorV1") + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.BaseEstimatorV1.mdx b/docs/api/qiskit/1.0/qiskit.primitives.BaseEstimatorV1.mdx new file mode 100644 index 00000000000..b1506cbb3de --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.BaseEstimatorV1.mdx @@ -0,0 +1,137 @@ +--- +title: BaseEstimatorV1 +description: API reference for qiskit.primitives.BaseEstimatorV1 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.BaseEstimatorV1 +--- + +# BaseEstimatorV1 + + + Bases: `BasePrimitive`, [`Generic`](https://docs.python.org/3/library/typing.html#typing.Generic "(in Python v3.12)")\[`T`] + + Estimator V1 base class. + + Base class for Estimator that 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}") + ``` + + 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 + + ### options + + + Return options values for the estimator. + + **Returns** + + options + + + ## Methods + + ### run + + + 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]. + ``` + + **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 |* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | BaseOperator |* [*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 values for the estimator. + + **Parameters** + + **\*\*fields** – The fields to update the options + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.BaseEstimatorV2.mdx b/docs/api/qiskit/1.0/qiskit.primitives.BaseEstimatorV2.mdx new file mode 100644 index 00000000000..6f2724a035f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.BaseEstimatorV2.mdx @@ -0,0 +1,41 @@ +--- +title: BaseEstimatorV2 +description: API reference for qiskit.primitives.BaseEstimatorV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.BaseEstimatorV2 +--- + +# BaseEstimatorV2 + + + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + + Estimator V2 base class. + + An estimator estimates expectation values for provided quantum circuit and observable combinations. + + An Estimator implementation must treat the [`run()`](#qiskit.primitives.BaseEstimatorV2.run "qiskit.primitives.BaseEstimatorV2.run") method `precision=None` kwarg as using a default `precision` value. The default value and methods to set it can be determined by the Estimator implementor. + + ## Methods + + ### run + + + Estimate expectation values for each provided pub (Primitive Unified Bloc). + + **Parameters** + + * **pubs** (*Iterable\[EstimatorPubLike]*) – An iterable of pub-like objects, such as tuples `(circuit, observables)` or `(circuit, observables, parameter_values)`. + * **precision** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The target precision for expectation value estimates of each run Estimator Pub that does not specify its own precision. If None the estimator’s default precision value will be used. + + **Returns** + + A job object that contains results. + + **Return type** + + [BasePrimitiveJob](qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[[PubResult](qiskit.primitives.PubResult "qiskit.primitives.PubResult")]] + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.BasePrimitiveJob.mdx b/docs/api/qiskit/1.0/qiskit.primitives.BasePrimitiveJob.mdx new file mode 100644 index 00000000000..2ccb2281c06 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.BasePrimitiveJob.mdx @@ -0,0 +1,101 @@ +--- +title: BasePrimitiveJob +description: API reference for qiskit.primitives.BasePrimitiveJob +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.BasePrimitiveJob +--- + +# BasePrimitiveJob + + + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)"), [`Generic`](https://docs.python.org/3/library/typing.html#typing.Generic "(in Python v3.12)")\[`ResultT`, `StatusT`] + + Primitive job abstract base class. + + Initializes the primitive job. + + **Parameters** + + * **job\_id** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – A unique id in the context of the primitive used to run the job. + * **kwargs** – Any key value metadata to associate with this job. + + ## Methods + + ### cancel + + + Attempt to cancel the job. + + + ### 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 + + + 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 + + + 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 + + + Return a unique id identifying the job. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### result + + + Return the results of the job. + + **Return type** + + *ResultT* + + + ### 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 + + + Return the status of the job. + + **Return type** + + *StatusT* + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.BaseSampler.mdx b/docs/api/qiskit/1.0/qiskit.primitives.BaseSampler.mdx new file mode 100644 index 00000000000..1fff1e5773f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.BaseSampler.mdx @@ -0,0 +1,14 @@ +--- +title: BaseSampler +description: API reference for qiskit.primitives.BaseSampler +in_page_toc_min_heading_level: 1 +python_api_type: attribute +python_api_name: qiskit.primitives.BaseSampler +--- + +# BaseSampler + + + alias of [`BaseSamplerV1`](qiskit.primitives.BaseSamplerV1 "qiskit.primitives.base.base_sampler.BaseSamplerV1") + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.BaseSamplerV1.mdx b/docs/api/qiskit/1.0/qiskit.primitives.BaseSamplerV1.mdx new file mode 100644 index 00000000000..815c5cdf450 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.BaseSamplerV1.mdx @@ -0,0 +1,116 @@ +--- +title: BaseSamplerV1 +description: API reference for qiskit.primitives.BaseSamplerV1 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.BaseSamplerV1 +--- + +# BaseSamplerV1 + + + Bases: `BasePrimitive`, [`Generic`](https://docs.python.org/3/library/typing.html#typing.Generic "(in Python v3.12)")\[`T`] + + Sampler V1 base class + + Base class of Sampler that calculates 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]) + ``` + + **Parameters** + + **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – Default options. + + ## Attributes + + ### options + + + Return options values for the estimator. + + **Returns** + + options + + + ## Methods + + ### run + + + 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 values for the estimator. + + **Parameters** + + **\*\*fields** – The fields to update the options + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.BaseSamplerV2.mdx b/docs/api/qiskit/1.0/qiskit.primitives.BaseSamplerV2.mdx new file mode 100644 index 00000000000..011ccd578fe --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.BaseSamplerV2.mdx @@ -0,0 +1,41 @@ +--- +title: BaseSamplerV2 +description: API reference for qiskit.primitives.BaseSamplerV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.BaseSamplerV2 +--- + +# BaseSamplerV2 + + + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + + Sampler V2 base class. + + A Sampler returns samples of quantum circuit outputs. + + All sampler implementations must implement default value for the `shots` in the [`run()`](#qiskit.primitives.BaseSamplerV2.run "qiskit.primitives.BaseSamplerV2.run") method if `None` is given both as a `kwarg` and in all of the pubs. + + ## Methods + + ### run + + + Run and collect samples from each pub. + + **Parameters** + + * **pubs** (*Iterable\[SamplerPubLike]*) – An iterable of pub-like objects. For example, a list of circuits or tuples `(circuit, parameter_values)`. + * **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The total number of shots to sample for each sampler pub that does not specify its own shots. If `None`, the primitive’s default shots value will be used, which can vary by implementation. + + **Returns** + + The job object of Sampler’s result. + + **Return type** + + [BasePrimitiveJob](qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[[PubResult](qiskit.primitives.PubResult "qiskit.primitives.PubResult")]] + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.BitArray.mdx b/docs/api/qiskit/1.0/qiskit.primitives.BitArray.mdx new file mode 100644 index 00000000000..e8ae6ea3751 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.BitArray.mdx @@ -0,0 +1,230 @@ +--- +title: BitArray +description: API reference for qiskit.primitives.BitArray +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.BitArray +--- + +# BitArray + + + Bases: `ShapedMixin` + + Stores an array of bit values. + + This object contains a single, contiguous block of data that represents an array of bitstrings. The last axis is over packed bits, the second last axis is over shots, and the preceding axes correspond to the shape of the pub that was executed to sample these bits. + + **Parameters** + + * **array** (*NDArray\[np.uint8]*) – The `uint8` data array. + * **num\_bits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – How many bit are in each outcome. + + **Raises** + + * [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If the input is not a NumPy array with type `numpy.uint8`. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the input array has fewer than two axes, or the size of the last axis is not the smallest number of bytes that can contain `num_bits`. + + ## Attributes + + ### array + + + The raw NumPy array of data. + + + ### ndim + + + + ### num\_bits + + + The number of bits in the register that this array stores data for. + + For example, a `ClassicalRegister(5, "meas")` would result in `num_bits=5`. + + + ### num\_shots + + + The number of shots sampled from the register in each configuration. + + More precisely, the length of the second last axis of [`array`](#qiskit.primitives.BitArray.array "qiskit.primitives.BitArray.array"). + + + ### shape + + + + ### size + + + + ## Methods + + ### bitcount + + + Compute the number of ones appearing in the binary representation of each shot. + + **Returns** + + A `numpy.uint64`-array with shape `(*shape, num_shots)`. + + **Return type** + + [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [*dtype*](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v1.26)")\[*uint64*]] + + + ### from\_bool\_array + + + Construct a new bit array from an array of bools. + + **Parameters** + + * **array** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")*\[*[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*,* [*dtype*](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v1.26)")*\[*[*bool\_*](https://numpy.org/doc/stable/reference/arrays.scalars.html#numpy.bool_ "(in NumPy v1.26)")*]]*) – The array to convert, with “bitstrings” along the last axis. + * **order** ([*Literal*](https://docs.python.org/3/library/typing.html#typing.Literal "(in Python v3.12)")*\['big', 'little']*) – One of `"big"` or `"little"`, indicating whether `array[..., 0]` correspond to the most significant bits or the least significant bits of each bitstring, respectively. + + **Returns** + + A new bit array. + + **Return type** + + [*BitArray*](#qiskit.primitives.BitArray "qiskit.primitives.containers.bit_array.BitArray") + + + ### from\_counts + + + Construct a new bit array from one or more `Counts`-like objects. + + The `counts` can have keys that are (uniformly) integers, hexstrings, or bitstrings. Their values represent numbers of occurrences of that value. + + **Parameters** + + * **counts** (*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)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | Iterable\[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)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – One or more counts-like mappings with the same number of shots. + * **num\_bits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The desired number of bits per shot. If unset, the biggest value found sets this value. + + **Returns** + + A new bit array with shape `()` for single input counts, or `(N,)` for an iterable of $N$ counts. + + **Raises** + + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If different mappings have different numbers of shots. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If no counts dictionaries are supplied. + + **Return type** + + [BitArray](#qiskit.primitives.BitArray "qiskit.primitives.BitArray") + + + ### from\_samples + + + Construct a new bit array from an iterable of bitstrings, hexstrings, or integers. + + All samples are assumed to be integers if the first one is. Strings are all assumed to be bitstrings whenever the first string doesn’t start with `"0x"`. + + Consider pairing this method with [`reshape()`](#qiskit.primitives.BitArray.reshape "qiskit.primitives.BitArray.reshape") if your samples represent nested data. + + **Parameters** + + * **samples** (*Iterable\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | Iterable\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A list of bitstrings, a list of integers, or a list of hexstrings. + * **num\_bits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The desired number of bits per sample. If unset, the biggest sample provided is used to determine this value. + + **Returns** + + A new bit array. + + **Raises** + + [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If no strings are given. + + **Return type** + + [BitArray](#qiskit.primitives.BitArray "qiskit.primitives.BitArray") + + + ### get\_bitstrings + + + Return a list of bitstrings. + + **Parameters** + + **loc** ([*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)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, ...] | None*) – Which entry of this array to return a dictionary for. If `None`, counts from all positions in this array are unioned together. + + **Returns** + + A list of bitstrings. + + **Return type** + + [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)")] + + + ### get\_counts + + + Return a counts dictionary with bitstring keys. + + **Parameters** + + **loc** ([*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)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, ...] | None*) – Which entry of this array to return a dictionary for. If `None`, counts from all positions in this array are unioned together. + + **Returns** + + A dictionary mapping bitstrings to the number of occurrences of that bitstring. + + **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)")] + + + ### get\_int\_counts + + + Return a counts dictionary, where bitstrings are stored as `int`s. + + **Parameters** + + **loc** ([*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)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, ...] | None*) – Which entry of this array to return a dictionary for. If `None`, counts from all positions in this array are unioned together. + + **Returns** + + A dictionary mapping `ints` to the number of occurrences of that `int`. + + **Return type** + + [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)")] + + + ### reshape + + + Return a new reshaped bit array. + + The [`num_shots`](#qiskit.primitives.BitArray.num_shots "qiskit.primitives.BitArray.num_shots") axis is either included or excluded from the reshaping procedure depending on which picture the new shape is compatible with. For example, for a bit array with shape `(20, 5)` and `64` shots, a reshape to `(100,)` would leave the number of shots intact, whereas a reshape to `(200, 32)` would change the number of shots to `32`. + + **Parameters** + + **\*shape** ([*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)") *| Iterable\[ShapeInput]]*) – The new desired shape. + + **Returns** + + A new bit array. + + **Raises** + + [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the size corresponding to your new shape is not equal to either [`size`](#qiskit.primitives.BitArray.size "qiskit.primitives.BitArray.size"), or the product of [`size`](#qiskit.primitives.BitArray.size "qiskit.primitives.BitArray.size") and [`num_shots`](#qiskit.primitives.BitArray.num_shots "qiskit.primitives.BitArray.num_shots"). + + **Return type** + + [*BitArray*](#qiskit.primitives.BitArray "qiskit.primitives.containers.bit_array.BitArray") + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.DataBin.mdx b/docs/api/qiskit/1.0/qiskit.primitives.DataBin.mdx new file mode 100644 index 00000000000..224e4fdf5e4 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.DataBin.mdx @@ -0,0 +1,18 @@ +--- +title: DataBin +description: API reference for qiskit.primitives.DataBin +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.DataBin +--- + +# DataBin + + + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + + Base class for data bin containers. + + Subclasses are typically made via `make_data_bin`, which is a specialization of `make_dataclass`. + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.Estimator.mdx b/docs/api/qiskit/1.0/qiskit.primitives.Estimator.mdx new file mode 100644 index 00000000000..dfc20b7599c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.Estimator.mdx @@ -0,0 +1,97 @@ +--- +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 + + + Bases: [`BaseEstimatorV1`](qiskit.primitives.BaseEstimatorV1 "qiskit.primitives.base.base_estimator.BaseEstimatorV1")\[[`PrimitiveJob`](qiskit.primitives.PrimitiveJob "qiskit.primitives.primitive_job.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 + + ### options + + + Return options values for the estimator. + + **Returns** + + options + + + ## Methods + + ### run + + + 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]. + ``` + + **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 |* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | BaseOperator |* [*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 values for the estimator. + + **Parameters** + + **\*\*fields** – The fields to update the options + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.EstimatorResult.mdx b/docs/api/qiskit/1.0/qiskit.primitives.EstimatorResult.mdx new file mode 100644 index 00000000000..be128ea68c6 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.EstimatorResult.mdx @@ -0,0 +1,37 @@ +--- +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 + + + 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 + + ### values + + + + ### metadata + + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.PrimitiveJob.mdx b/docs/api/qiskit/1.0/qiskit.primitives.PrimitiveJob.mdx new file mode 100644 index 00000000000..db830d70b9c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.PrimitiveJob.mdx @@ -0,0 +1,98 @@ +--- +title: PrimitiveJob +description: API reference for qiskit.primitives.PrimitiveJob +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.PrimitiveJob +--- + +# PrimitiveJob + + + Bases: [`BasePrimitiveJob`](qiskit.primitives.BasePrimitiveJob "qiskit.primitives.base.base_primitive_job.BasePrimitiveJob")\[`ResultT`, [`JobStatus`](qiskit.providers.JobStatus "qiskit.providers.jobstatus.JobStatus")] + + Primitive job class for the reference implementations of Primitives. + + **Parameters** + + **function** – A callable function to execute the job. + + ## Methods + + ### cancel + + + Attempt to cancel the job. + + + ### 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 + + + 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 + + + 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 + + + Return a unique id identifying the job. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### result + + + Return the results of the job. + + **Return type** + + *ResultT* + + + ### 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 + + + Return the status of the job. + + **Return type** + + [*JobStatus*](qiskit.providers.JobStatus "qiskit.providers.jobstatus.JobStatus") + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.PrimitiveResult.mdx b/docs/api/qiskit/1.0/qiskit.primitives.PrimitiveResult.mdx new file mode 100644 index 00000000000..386128a7a14 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.PrimitiveResult.mdx @@ -0,0 +1,29 @@ +--- +title: PrimitiveResult +description: API reference for qiskit.primitives.PrimitiveResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.PrimitiveResult +--- + +# PrimitiveResult + + + Bases: [`Generic`](https://docs.python.org/3/library/typing.html#typing.Generic "(in Python v3.12)")\[`T`] + + A container for multiple pub results and global metadata. + + **Parameters** + + * **pub\_results** (*Iterable\[T]*) – Pub results. + * **metadata** ([*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*) – Metadata that is common to all pub results; metadata specific to particular pubs should be placed in their metadata fields. Keys are expected to be strings. + + ## Attributes + + ### metadata + + + The metadata of this primitive result. + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.PubResult.mdx b/docs/api/qiskit/1.0/qiskit.primitives.PubResult.mdx new file mode 100644 index 00000000000..9797236055c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.PubResult.mdx @@ -0,0 +1,37 @@ +--- +title: PubResult +description: API reference for qiskit.primitives.PubResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.PubResult +--- + +# PubResult + + + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + + Result of Primitive Unified Bloc. + + Initialize a pub result. + + **Parameters** + + * **data** ([*DataBin*](qiskit.primitives.DataBin "qiskit.primitives.DataBin")) – Result data. + * **metadata** ([*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*) – Metadata specific to this pub. Keys are expected to be strings. + + ## Attributes + + ### data + + + Result data for the pub. + + + ### metadata + + + Metadata for the pub. + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.Sampler.mdx b/docs/api/qiskit/1.0/qiskit.primitives.Sampler.mdx new file mode 100644 index 00000000000..4a1d3693690 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.Sampler.mdx @@ -0,0 +1,79 @@ +--- +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 + + + Bases: [`BaseSamplerV1`](qiskit.primitives.BaseSamplerV1 "qiskit.primitives.base.base_sampler.BaseSamplerV1")\[[`PrimitiveJob`](qiskit.primitives.PrimitiveJob "qiskit.primitives.primitive_job.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 + + ### options + + + Return options values for the estimator. + + **Returns** + + options + + + ## Methods + + ### run + + + 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 values for the estimator. + + **Parameters** + + **\*\*fields** – The fields to update the options + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.SamplerResult.mdx b/docs/api/qiskit/1.0/qiskit.primitives.SamplerResult.mdx new file mode 100644 index 00000000000..68522a1e805 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.SamplerResult.mdx @@ -0,0 +1,37 @@ +--- +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 + + + 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 + + ### quasi\_dists + + + + ### metadata + + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.StatevectorEstimator.mdx b/docs/api/qiskit/1.0/qiskit.primitives.StatevectorEstimator.mdx new file mode 100644 index 00000000000..4c842482a66 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.StatevectorEstimator.mdx @@ -0,0 +1,121 @@ +--- +title: StatevectorEstimator +description: API reference for qiskit.primitives.StatevectorEstimator +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.StatevectorEstimator +--- + +# StatevectorEstimator + + + Bases: [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.base.base_estimator.BaseEstimatorV2") + + Simple implementation of [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") with full state vector simulation. + + This class is implemented via [`Statevector`](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") which turns provided circuits into pure state vectors. These states are subsequently acted on by :class:\~.SparsePauliOp\`, which implies that, at present, this implementation is only compatible with Pauli-based observables. + + Each tuple of `(circuit, observables, parameter values, precision)`, called an estimator primitive unified bloc (PUB), produces its own array-based result. The `run()` method can be given a sequence of pubs to run in one call. + + ```python + from qiskit.circuit import Parameter, QuantumCircuit + from qiskit.primitives import StatevectorEstimator + from qiskit.quantum_info import Pauli, SparsePauliOp + + import matplotlib.pyplot as plt + import numpy as np + + # Define a circuit with two parameters. + circuit = QuantumCircuit(2) + circuit.h(0) + circuit.cx(0, 1) + circuit.ry(Parameter("a"), 0) + circuit.rz(Parameter("b"), 0) + circuit.cx(0, 1) + circuit.h(0) + + # Define a sweep over parameter values, where the second axis is over + # the two parameters in the circuit. + params = np.vstack([ + np.linspace(-np.pi, np.pi, 100), + np.linspace(-4 * np.pi, 4 * np.pi, 100) + ]).T + + # Define three observables. Many formats are supported here including + # classes such as qiskit.quantum_info.SparsePauliOp. The inner length-1 + # lists cause this array of observables to have shape (3, 1), rather + # than shape (3,) if they were omitted. + observables = [ + [SparsePauliOp(["XX", "IY"], [0.5, 0.5])], + [Pauli("XX")], + [Pauli("IY")] + ] + + # Instantiate a new statevector simulation based estimator object. + estimator = StatevectorEstimator() + + # Estimate the expectation value for all 300 combinations of + # observables and parameter values, where the pub result will have + # shape (3, 100). This shape is due to our array of parameter + # bindings having shape (100,), combined with our array of observables + # having shape (3, 1) + pub = (circuit, observables, params) + job = estimator.run([pub]) + + # Extract the result for the 0th pub (this example only has one pub). + result = job.result()[0] + + # Error-bar information is also available, but the error is 0 + # for this StatevectorEstimator. + result.data.stds + + # Pull out the array-based expectation value estimate data from the + # result and plot a trace for each observable. + for idx, pauli in enumerate(observables): + plt.plot(result.data.evs[idx], label=pauli) + plt.legend() + ``` + + ![../\_images/qiskit-primitives-StatevectorEstimator-1.png](/images/api/qiskit/1.0/qiskit-primitives-StatevectorEstimator-1.png) + + **Parameters** + + * **default\_precision** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The default precision for the estimator if not specified during run. + * **seed** (*np.random.Generator |* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The seed or Generator object for random number generation. If None, a random seeded default RNG will be used. + + ## Attributes + + ### default\_precision + + + Return the default precision + + + ### seed + + + Return the seed or Generator object for random number generation. + + + ## Methods + + ### run + + + Estimate expectation values for each provided pub (Primitive Unified Bloc). + + **Parameters** + + * **pubs** (*Iterable\[EstimatorPubLike]*) – An iterable of pub-like objects, such as tuples `(circuit, observables)` or `(circuit, observables, parameter_values)`. + * **precision** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The target precision for expectation value estimates of each run Estimator Pub that does not specify its own precision. If None the estimator’s default precision value will be used. + + **Returns** + + A job object that contains results. + + **Return type** + + [PrimitiveJob](qiskit.primitives.PrimitiveJob "qiskit.primitives.PrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[[PubResult](qiskit.primitives.PubResult "qiskit.primitives.PubResult")]] + + + diff --git a/docs/api/qiskit/1.0/qiskit.primitives.StatevectorSampler.mdx b/docs/api/qiskit/1.0/qiskit.primitives.StatevectorSampler.mdx new file mode 100644 index 00000000000..59c9ea20d0c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.primitives.StatevectorSampler.mdx @@ -0,0 +1,128 @@ +--- +title: StatevectorSampler +description: API reference for qiskit.primitives.StatevectorSampler +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.StatevectorSampler +--- + +# StatevectorSampler + + + Bases: [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.base.base_sampler.BaseSamplerV2") + + Simple implementation of [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") using full state vector simulation. + + This class is implemented via [`Statevector`](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") which turns provided circuits into pure state vectors, and is therefore incompatible with mid-circuit measurements (although other implementations may be). + + As seen in the example below, this sampler supports providing arrays of parameter value sets to bind against a single circuit. + + Each tuple of `(circuit, parameter values, shots)`, called a sampler primitive unified bloc (PUB), produces its own array-valued result. The [`run()`](#qiskit.primitives.StatevectorSampler.run "qiskit.primitives.StatevectorSampler.run") method can be given many pubs at once. + + ```python + from qiskit.circuit import ( + Parameter, QuantumCircuit, ClassicalRegister, QuantumRegister + ) + from qiskit.primitives import StatevectorSampler + + import matplotlib.pyplot as plt + import numpy as np + + # Define our circuit registers, including classical registers + # called 'alpha' and 'beta'. + qreg = QuantumRegister(3) + alpha = ClassicalRegister(2, "alpha") + beta = ClassicalRegister(1, "beta") + + # Define a quantum circuit with two parameters. + circuit = QuantumCircuit(qreg, alpha, beta) + circuit.h(0) + circuit.cx(0, 1) + circuit.cx(1, 2) + circuit.ry(Parameter("a"), 0) + circuit.rz(Parameter("b"), 0) + circuit.cx(1, 2) + circuit.cx(0, 1) + circuit.h(0) + circuit.measure([0, 1], alpha) + circuit.measure([2], beta) + + # Define a sweep over parameter values, where the second axis is over. + # the two parameters in the circuit. + params = np.vstack([ + np.linspace(-np.pi, np.pi, 100), + np.linspace(-4 * np.pi, 4 * np.pi, 100) + ]).T + + # Instantiate a new statevector simulation based sampler object. + sampler = StatevectorSampler() + + # Start a job that will return shots for all 100 parameter value sets. + pub = (circuit, params) + job = sampler.run([pub], shots=256) + + # Extract the result for the 0th pub (this example only has one pub). + result = job.result()[0] + + # There is one BitArray object for each ClassicalRegister in the + # circuit. Here, we can see that the BitArray for alpha contains data + # for all 100 sweep points, and that it is indeed storing data for 2 + # bits over 256 shots. + assert result.data.alpha.shape == (100,) + assert result.data.alpha.num_bits == 2 + assert result.data.alpha.num_shots == 256 + + # We can work directly with a binary array in performant applications. + raw = result.data.alpha.array + + # For small registers where it is anticipated to have many counts + # associated with the same bitstrings, we can turn the data from, + # for example, the 22nd sweep index into a dictionary of counts. + counts = result.data.alpha.get_counts(22) + + # Or, convert into a list of bitstrings that preserve shot order. + bitstrings = result.data.alpha.get_bitstrings(22) + print(bitstrings) + ``` + + **Parameters** + + * **default\_shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The default shots for the sampler if not specified during run. + * **seed** (*np.random.Generator |* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The seed or Generator object for random number generation. If None, a random seeded default RNG will be used. + + ## Attributes + + ### default\_shots + + + Return the default shots + + + ### seed + + + Return the seed or Generator object for random number generation. + + + ## Methods + + ### run + + + Run and collect samples from each pub. + + **Parameters** + + * **pubs** (*Iterable\[SamplerPubLike]*) – An iterable of pub-like objects. For example, a list of circuits or tuples `(circuit, parameter_values)`. + * **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The total number of shots to sample for each sampler pub that does not specify its own shots. If `None`, the primitive’s default shots value will be used, which can vary by implementation. + + **Returns** + + The job object of Sampler’s result. + + **Return type** + + [PrimitiveJob](qiskit.primitives.PrimitiveJob "qiskit.primitives.PrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[[PubResult](qiskit.primitives.PubResult "qiskit.primitives.PubResult")]] + + + diff --git a/docs/api/qiskit/1.0/qiskit.providers.Backend.mdx b/docs/api/qiskit/1.0/qiskit.providers.Backend.mdx new file mode 100644 index 00000000000..d24e1237652 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.Backend.mdx @@ -0,0 +1,24 @@ +--- +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 + + + 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 + + + + diff --git a/docs/api/qiskit/1.0/qiskit.providers.BackendV1.mdx b/docs/api/qiskit/1.0/qiskit.providers.BackendV1.mdx new file mode 100644 index 00000000000..1861e7190df --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.BackendV1.mdx @@ -0,0 +1,193 @@ +--- +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 + + + 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 + + + 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: + + + 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 + + + + ## Methods + + ### configuration + + + Return the backend configuration. + + **Returns** + + the configuration for the backend. + + **Return type** + + [BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + + + ### 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 + + + 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 + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + [Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + ### run + + + 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 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 + + + 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/1.0/qiskit.providers.BackendV2.mdx b/docs/api/qiskit/1.0/qiskit.providers.BackendV2.mdx new file mode 100644 index 00000000000..0e6db3a3d61 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.BackendV2.mdx @@ -0,0 +1,362 @@ +--- +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 + + + 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 + + + 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 + + + + ### 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 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 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/1.0/qiskit.providers.BackendV2Converter.mdx b/docs/api/qiskit/1.0/qiskit.providers.BackendV2Converter.mdx new file mode 100644 index 00000000000..6295c6a0aea --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.BackendV2Converter.mdx @@ -0,0 +1,315 @@ +--- +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 + + + 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 + + + + ### 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 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 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/1.0/qiskit.providers.Job.mdx b/docs/api/qiskit/1.0/qiskit.providers.Job.mdx new file mode 100644 index 00000000000..7a7520114c1 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.Job.mdx @@ -0,0 +1,24 @@ +--- +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 + + + 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 + + + + diff --git a/docs/api/qiskit/1.0/qiskit.providers.JobStatus.mdx b/docs/api/qiskit/1.0/qiskit.providers.JobStatus.mdx new file mode 100644 index 00000000000..d6cd805a450 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.JobStatus.mdx @@ -0,0 +1,46 @@ +--- +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 + + + Bases: [`Enum`](https://docs.python.org/3/library/enum.html#enum.Enum "(in Python v3.12)") + + Class for job status enumerated type. + + ## Attributes + + ### INITIALIZING + + + + ### QUEUED + + + + ### VALIDATING + + + + ### RUNNING + + + + ### CANCELLED + + + + ### DONE + + + + ### ERROR + + + + diff --git a/docs/api/qiskit/1.0/qiskit.providers.JobV1.mdx b/docs/api/qiskit/1.0/qiskit.providers.JobV1.mdx new file mode 100644 index 00000000000..d57a09a6d00 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.JobV1.mdx @@ -0,0 +1,152 @@ +--- +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 + + + 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** (*Optional\[*[*Backend*](qiskit.providers.Backend "qiskit.providers.Backend")*]*) – 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 + + + + ## Methods + + ### backend + + + Return the backend where this job was executed. + + **Return type** + + [*Backend*](qiskit.providers.Backend "qiskit.providers.backend.Backend") + + + ### cancel + + + Attempt to cancel the job. + + + ### 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 + + + 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 + + + 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 + + + Return a unique id identifying the job. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### result + + + Return the results of the job. + + **Return type** + + [Result](qiskit.result.Result "qiskit.result.Result") + + + ### 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 + + + Return the status of the job, among the values of `JobStatus`. + + **Return type** + + [*JobStatus*](qiskit.providers.JobStatus "qiskit.providers.jobstatus.JobStatus") + + + ### submit + + + Submit the job to the backend for execution. + + + ### wait\_for\_final\_state + + + 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/1.0/qiskit.providers.Options.mdx b/docs/api/qiskit/1.0/qiskit.providers.Options.mdx new file mode 100644 index 00000000000..1ddcdac534b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.Options.mdx @@ -0,0 +1,111 @@ +--- +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 + + + 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 + + + + ### items + + + + ### keys + + + + ### set\_validator + + + 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 with kwargs + + + ### values + + + + diff --git a/docs/api/qiskit/1.0/qiskit.providers.Provider.mdx b/docs/api/qiskit/1.0/qiskit.providers.Provider.mdx new file mode 100644 index 00000000000..66c35d44047 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.Provider.mdx @@ -0,0 +1,24 @@ +--- +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 + + + 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 + + + + diff --git a/docs/api/qiskit/1.0/qiskit.providers.ProviderV1.mdx b/docs/api/qiskit/1.0/qiskit.providers.ProviderV1.mdx new file mode 100644 index 00000000000..98ccf88ad2b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.ProviderV1.mdx @@ -0,0 +1,68 @@ +--- +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 + + + 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 + + + + ## Methods + + ### backends + + + 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 + + + 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/1.0/qiskit.providers.QubitProperties.mdx b/docs/api/qiskit/1.0/qiskit.providers.QubitProperties.mdx new file mode 100644 index 00000000000..5d9745c86dd --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.QubitProperties.mdx @@ -0,0 +1,40 @@ +--- +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 + + + 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/1.0/qiskit.providers.basic_provider.BasicProvider.mdx b/docs/api/qiskit/1.0/qiskit.providers.basic_provider.BasicProvider.mdx new file mode 100644 index 00000000000..7208d01b86e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.basic_provider.BasicProvider.mdx @@ -0,0 +1,68 @@ +--- +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 + + + Bases: [`ProviderV1`](qiskit.providers.ProviderV1 "qiskit.providers.provider.ProviderV1") + + Provider for test simulators. + + ## Attributes + + ### version + + + + ## Methods + + ### backends + + + 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 + + + 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/1.0/qiskit.providers.basic_provider.BasicProviderError.mdx b/docs/api/qiskit/1.0/qiskit.providers.basic_provider.BasicProviderError.mdx new file mode 100644 index 00000000000..fe33a9c651f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.basic_provider.BasicProviderError.mdx @@ -0,0 +1,18 @@ +--- +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 + + + Base class for errors raised by the Basic Provider. + + Set the error message. + + diff --git a/docs/api/qiskit/1.0/qiskit.providers.basic_provider.BasicProviderJob.mdx b/docs/api/qiskit/1.0/qiskit.providers.basic_provider.BasicProviderJob.mdx new file mode 100644 index 00000000000..3ec6eea0ff4 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.basic_provider.BasicProviderJob.mdx @@ -0,0 +1,158 @@ +--- +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 + + + 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 + + + + ## Methods + + ### backend + + + Return the instance of the backend used for this job. + + + ### cancel + + + Attempt to cancel the job. + + + ### 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 + + + 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 + + + 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 + + + Return a unique id identifying the job. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### result + + + Get job result . + + **Returns** + + Result object + + **Return type** + + [qiskit.result.Result](qiskit.result.Result "qiskit.result.Result") + + + ### 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 + + + 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 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 + + + 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/1.0/qiskit.providers.basic_provider.BasicSimulator.mdx b/docs/api/qiskit/1.0/qiskit.providers.basic_provider.BasicSimulator.mdx new file mode 100644 index 00000000000..caba9da8dd4 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.basic_provider.BasicSimulator.mdx @@ -0,0 +1,389 @@ +--- +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 + + + 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 + + + + ### 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 + + + + ### 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 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 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 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/1.0/qiskit.providers.convert_to_target.mdx b/docs/api/qiskit/1.0/qiskit.providers.convert_to_target.mdx new file mode 100644 index 00000000000..8e65c5dae49 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.convert_to_target.mdx @@ -0,0 +1,31 @@ +--- +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 + + + Decode transpiler target from backend data set. + + This function generates `` Target` `` instance from intermediate legacy objects such as [`BackendProperties`](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") and [`PulseDefaults`](qiskit.providers.models.PulseDefaults "qiskit.providers.models.PulseDefaults"). These objects are usually components of the legacy [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") model. + + **Parameters** + + * **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.backendconfiguration.BackendConfiguration")) – Backend configuration as `BackendConfiguration` + * **properties** ([*BackendProperties*](qiskit.providers.models.BackendProperties "qiskit.providers.models.backendproperties.BackendProperties") *| None*) – Backend property dictionary or `BackendProperties` + * **defaults** ([*PulseDefaults*](qiskit.providers.models.PulseDefaults "qiskit.providers.models.pulsedefaults.PulseDefaults") *| None*) – Backend pulse defaults dictionary or `PulseDefaults` + * **custom\_name\_mapping** ([*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*) – A name mapping must be supplied for the operation not included in Qiskit Standard Gate name mapping, otherwise the operation will be dropped in the resulting `Target` object. + * **add\_delay** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, adds delay to the instruction set. + * **filter\_faulty** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, this filters the non-operational qubits. + + **Returns** + + A `Target` instance. + + diff --git a/docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake127QPulseV1.mdx b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake127QPulseV1.mdx new file mode 100644 index 00000000000..7394a738793 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake127QPulseV1.mdx @@ -0,0 +1,159 @@ +--- +title: Fake127QPulseV1 +description: API reference for qiskit.providers.fake_provider.Fake127QPulseV1 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.Fake127QPulseV1 +--- + +# Fake127QPulseV1 + + + Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + + A fake **pulse** backend with the following characteristics: + + * num\_qubits: 127 + + * coupling\_map: heavy-hex based + + * basis\_gates: `["id", "rz", "sx", "x", "cx", "reset"]` + + * **scheduled instructions:** + + \# `{'id', 'measure', 'u2', 'rz', 'x', 'u3', 'sx', 'u1'}` for all individual qubits # `{'cx'}` for all edges # `{'measure'}` for (0, …, 127) + + 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 + + + + ### conf\_filename + + + + ### defs\_filename + + + + ### dirname + + + + ### 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.Fake127QPulseV1.run "qiskit.providers.fake_provider.Fake127QPulseV1.run") method. + + + ### props\_filename + + + + ### version + + + + ## Methods + + ### configuration + + + Return the backend configuration. + + **Returns** + + the configuration for the backend. + + **Return type** + + [BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + + + ### defaults + + + Returns a snapshot of device defaults + + + ### 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 + + + Returns a snapshot of device properties + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + [Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + ### run + + + Main job in simulator + + + ### set\_options + + + 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 + + + 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/1.0/qiskit.providers.fake_provider.Fake1Q.mdx b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake1Q.mdx new file mode 100644 index 00000000000..ac5979bf19f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake1Q.mdx @@ -0,0 +1,118 @@ +--- +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 + + + 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 + + + + ## Methods + + ### configuration + + + Return the backend configuration. + + **Returns** + + the configuration for the backend. + + **Return type** + + [BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + + + ### 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 + + + Return backend properties + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + [Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + ### run + + + Main job in simulator + + + ### set\_options + + + 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 + + + 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/1.0/qiskit.providers.fake_provider.Fake20QV1.mdx b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake20QV1.mdx new file mode 100644 index 00000000000..f631e95c694 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake20QV1.mdx @@ -0,0 +1,155 @@ +--- +title: Fake20QV1 +description: API reference for qiskit.providers.fake_provider.Fake20QV1 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.Fake20QV1 +--- + +# Fake20QV1 + + + Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") + + A fake backend with the following characteristics: + + * num\_qubits: 20 + + * coupling\_map: + + > ```python + > 00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + > ↕ ↕ + > 05 ↔ 06 ↔ 07 ↔ 08 ↔ 09 + > ↕ ↕ ↕ + > 10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 + > ↕ ↕ + > 15 ↔ 16 ↔ 17 ↔ 18 ↔ 19 + > ``` + + * basis\_gates: `["id", "u1", "u2", "u3", "cx"]` + + 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 + + + + ### conf\_filename + + + + ### dirname + + + + ### 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.Fake20QV1.run "qiskit.providers.fake_provider.Fake20QV1.run") method. + + + ### props\_filename + + + + ### version + + + + ## Methods + + ### configuration + + + Return the backend configuration. + + **Returns** + + the configuration for the backend. + + **Return type** + + [BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + + + ### 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 + + + Returns a snapshot of device properties + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + [Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + ### run + + + Main job in simulator + + + ### set\_options + + + 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 + + + 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/1.0/qiskit.providers.fake_provider.Fake27QPulseV1.mdx b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake27QPulseV1.mdx new file mode 100644 index 00000000000..86f908025e0 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake27QPulseV1.mdx @@ -0,0 +1,171 @@ +--- +title: Fake27QPulseV1 +description: API reference for qiskit.providers.fake_provider.Fake27QPulseV1 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.Fake27QPulseV1 +--- + +# Fake27QPulseV1 + + + Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + + A fake **pulse** backend with the following characteristics: + + * num\_qubits: 27 + + * coupling\_map: + + > ```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 + > ``` + + * basis\_gates: `["id", "rz", "sx", "x", "cx", "reset"]` + + * **scheduled instructions:** + + \# `{'id', 'rz', 'u2', 'x', 'u3', 'sx', 'measure', 'u1'}` for all individual qubits # `{'cx'}` for all edges # `{'measure'}` for (0, …, 26) + + 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 + + + + ### conf\_filename + + + + ### defs\_filename + + + + ### dirname + + + + ### 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.Fake27QPulseV1.run "qiskit.providers.fake_provider.Fake27QPulseV1.run") method. + + + ### props\_filename + + + + ### version + + + + ## Methods + + ### configuration + + + Return the backend configuration. + + **Returns** + + the configuration for the backend. + + **Return type** + + [BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + + + ### defaults + + + Returns a snapshot of device defaults + + + ### 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 + + + Returns a snapshot of device properties + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + [Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + ### run + + + Main job in simulator + + + ### set\_options + + + 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 + + + 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/1.0/qiskit.providers.fake_provider.Fake5QV1.mdx b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake5QV1.mdx new file mode 100644 index 00000000000..85893eda6b0 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake5QV1.mdx @@ -0,0 +1,153 @@ +--- +title: Fake5QV1 +description: API reference for qiskit.providers.fake_provider.Fake5QV1 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.Fake5QV1 +--- + +# Fake5QV1 + + + Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") + + A fake backend with the following characteristics: + + * num\_qubits: 5 + + * coupling\_map: + + > ```python + > 1 + > / | + > 0 - 2 - 3 + > | / + > 4 + > ``` + + * basis\_gates: `["id", "rz", "sx", "x", "cx", "reset"]` + + 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 + + + + ### conf\_filename + + + + ### dirname + + + + ### 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.Fake5QV1.run "qiskit.providers.fake_provider.Fake5QV1.run") method. + + + ### props\_filename + + + + ### version + + + + ## Methods + + ### configuration + + + Return the backend configuration. + + **Returns** + + the configuration for the backend. + + **Return type** + + [BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + + + ### 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 + + + Returns a snapshot of device properties + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + [Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + ### run + + + Main job in simulator + + + ### set\_options + + + 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 + + + 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/1.0/qiskit.providers.fake_provider.Fake7QPulseV1.mdx b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake7QPulseV1.mdx new file mode 100644 index 00000000000..45da5745fcd --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.Fake7QPulseV1.mdx @@ -0,0 +1,165 @@ +--- +title: Fake7QPulseV1 +description: API reference for qiskit.providers.fake_provider.Fake7QPulseV1 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.Fake7QPulseV1 +--- + +# Fake7QPulseV1 + + + Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + + A fake **pulse** backend with the following characteristics: + + * num\_qubits: 7 + + * coupling\_map: + + > ```python + > 0 ↔ 1 ↔ 3 ↔ 5 ↔ 6 + > ↕ ↕ + > 2 4 + > ``` + + * basis\_gates: `["id", "rz", "sx", "x", "cx", "reset"]` + + * **scheduled instructions:** + + \# `{'u3', 'id', 'measure', 'u2', 'x', 'u1', 'sx', 'rz'}` for all individual qubits # `{'cx'}` for all edges # `{'measure'}` for (0, 1, 2, 3, 4, 5, 6) + + 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 + + + + ### conf\_filename + + + + ### defs\_filename + + + + ### dirname + + + + ### 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.Fake7QPulseV1.run "qiskit.providers.fake_provider.Fake7QPulseV1.run") method. + + + ### props\_filename + + + + ### version + + + + ## Methods + + ### configuration + + + Return the backend configuration. + + **Returns** + + the configuration for the backend. + + **Return type** + + [BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + + + ### defaults + + + Returns a snapshot of device defaults + + + ### 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 + + + Returns a snapshot of device properties + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + [Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + ### run + + + Main job in simulator + + + ### set\_options + + + 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 + + + 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/1.0/qiskit.providers.fake_provider.FakeOpenPulse2Q.mdx b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.FakeOpenPulse2Q.mdx new file mode 100644 index 00000000000..e4151bef0d8 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.FakeOpenPulse2Q.mdx @@ -0,0 +1,129 @@ +--- +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 + + + 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 + + + + ## Methods + + ### configuration + + + Return the backend configuration. + + **Returns** + + the configuration for the backend. + + **Return type** + + [BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + + + ### defaults + + + Return the default pulse-related settings provided by the backend (such as gate to Schedule mappings). + + + ### 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 + + + Return the measured characteristics of the backend. + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + [Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + ### run + + + Main job in simulator + + + ### set\_options + + + 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 + + + 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/1.0/qiskit.providers.fake_provider.FakeOpenPulse3Q.mdx b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.FakeOpenPulse3Q.mdx new file mode 100644 index 00000000000..2d6f571dc70 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.FakeOpenPulse3Q.mdx @@ -0,0 +1,127 @@ +--- +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 + + + 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 + + + + ## Methods + + ### configuration + + + Return the backend configuration. + + **Returns** + + the configuration for the backend. + + **Return type** + + [BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + + + ### defaults + + + + ### 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 + + + Return backend properties + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + [Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + ### run + + + Main job in simulator + + + ### set\_options + + + 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 + + + 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/1.0/qiskit.providers.fake_provider.GenericBackendV2.mdx b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.GenericBackendV2.mdx new file mode 100644 index 00000000000..c0c0da8dca9 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.fake_provider.GenericBackendV2.mdx @@ -0,0 +1,336 @@ +--- +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 + + + 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 + + + + ### 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 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 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/1.0/qiskit.providers.models.BackendConfiguration.mdx b/docs/api/qiskit/1.0/qiskit.providers.models.BackendConfiguration.mdx new file mode 100644 index 00000000000..a8fa51a694f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.models.BackendConfiguration.mdx @@ -0,0 +1,132 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.providers.models.BackendProperties.mdx b/docs/api/qiskit/1.0/qiskit.providers.models.BackendProperties.mdx new file mode 100644 index 00000000000..ee332a7de25 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.models.BackendProperties.mdx @@ -0,0 +1,288 @@ +--- +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 + + + 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 + + + Return a list of faulty gates. + + + ### faulty\_qubits + + + Return a list of faulty qubits. + + + ### frequency + + + 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 + + + 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 + + + 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 + + + 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 + + + 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** + + [*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(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)"), …], [*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)")\[[*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)")]]] | [*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)")\[[*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)")]] | [*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 + + + 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 + + + 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 + + + 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** + + [*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)")\[[*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)")]] | [*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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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/1.0/qiskit.providers.models.BackendStatus.mdx b/docs/api/qiskit/1.0/qiskit.providers.models.BackendStatus.mdx new file mode 100644 index 00000000000..39facb605e0 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.models.BackendStatus.mdx @@ -0,0 +1,64 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.providers.models.Command.mdx b/docs/api/qiskit/1.0/qiskit.providers.models.Command.mdx new file mode 100644 index 00000000000..63a613f8ffc --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.models.Command.mdx @@ -0,0 +1,65 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.providers.models.GateConfig.mdx b/docs/api/qiskit/1.0/qiskit.providers.models.GateConfig.mdx new file mode 100644 index 00000000000..273838a6e84 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.models.GateConfig.mdx @@ -0,0 +1,80 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.providers.models.GateProperties.mdx b/docs/api/qiskit/1.0/qiskit.providers.models.GateProperties.mdx new file mode 100644 index 00000000000..f123dc060b0 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.models.GateProperties.mdx @@ -0,0 +1,77 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.providers.models.JobStatus.mdx b/docs/api/qiskit/1.0/qiskit.providers.models.JobStatus.mdx new file mode 100644 index 00000000000..d914dfc9c41 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.models.JobStatus.mdx @@ -0,0 +1,80 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.providers.models.Nduv.mdx b/docs/api/qiskit/1.0/qiskit.providers.models.Nduv.mdx new file mode 100644 index 00000000000..8ef17c890b2 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.models.Nduv.mdx @@ -0,0 +1,83 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.providers.models.PulseBackendConfiguration.mdx b/docs/api/qiskit/1.0/qiskit.providers.models.PulseBackendConfiguration.mdx new file mode 100644 index 00000000000..38537e2e6c7 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.models.PulseBackendConfiguration.mdx @@ -0,0 +1,264 @@ +--- +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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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/1.0/qiskit.providers.models.PulseDefaults.mdx b/docs/api/qiskit/1.0/qiskit.providers.models.PulseDefaults.mdx new file mode 100644 index 00000000000..e10d14caff6 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.models.PulseDefaults.mdx @@ -0,0 +1,58 @@ +--- +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 + + + 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 + + + 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 + + + Return a dictionary format representation of the PulseDefaults. :returns: The dictionary form of the PulseDefaults. :rtype: dict + + + diff --git a/docs/api/qiskit/1.0/qiskit.providers.models.QasmBackendConfiguration.mdx b/docs/api/qiskit/1.0/qiskit.providers.models.QasmBackendConfiguration.mdx new file mode 100644 index 00000000000..6e2ae023c82 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.models.QasmBackendConfiguration.mdx @@ -0,0 +1,198 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.providers.models.UchannelLO.mdx b/docs/api/qiskit/1.0/qiskit.providers.models.UchannelLO.mdx new file mode 100644 index 00000000000..6350389b07a --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.providers.models.UchannelLO.mdx @@ -0,0 +1,73 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.pulse.InstructionScheduleMap.mdx b/docs/api/qiskit/1.0/qiskit.pulse.InstructionScheduleMap.mdx new file mode 100644 index 00000000000..13041fad5fc --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.InstructionScheduleMap.mdx @@ -0,0 +1,219 @@ +--- +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 + + + 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 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)") *|*[*circuit.instruction.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\[*[*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") *|*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *| Callable\[...,*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *|*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock")*]*) – The Schedule that implements the given instruction. + * **arguments** ([*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 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 + + + Error if the given instruction is not defined. + + **Parameters** + + * **instruction** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*circuit.instruction.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\[*[*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 + + + 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)") *|*[*circuit.instruction.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\[*[*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")) – 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")) – Keyworded command parameters for generating the schedule. + + **Returns** + + The Schedule defined for the input. + + **Return type** + + [Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") | [ScheduleBlock](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") + + + ### get\_parameters + + + 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)") *|*[*circuit.instruction.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\[*[*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/stdtypes.html#tuple "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), …] + + + ### has + + + Is the instruction defined for the given qubits? + + **Parameters** + + * **instruction** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*circuit.instruction.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\[*[*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 + + + 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 + + + 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)") *|*[*circuit.instruction.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\[*[*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")) – 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")) – Keyworded command parameters for generating the schedule. + + **Returns** + + The Schedule defined for the input. + + **Return type** + + [Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") | [ScheduleBlock](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") + + + ### qubit\_instructions + + + 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\[*[*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/stdtypes.html#list "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + + + ### qubits\_with\_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)") *|*[*circuit.instruction.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/stdtypes.html#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/stdtypes.html#tuple "(in Python v3.12)")\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"), …]] + + + ### remove + + + 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)") *|*[*circuit.instruction.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\[*[*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/1.0/qiskit.pulse.Schedule.mdx b/docs/api/qiskit/1.0/qiskit.pulse.Schedule.mdx new file mode 100644 index 00000000000..4ee5d33fc52 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.Schedule.mdx @@ -0,0 +1,464 @@ +--- +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 + + + 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/stdtypes.html#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 + + + + ### 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 + + + + ### start\_time + + + Starting time of this schedule. + + + ### stop\_time + + + Stopping time of this schedule. + + + ### timeslots + + + Time keeping attribute. + + + ## Methods + + ### append + + + 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** (*ScheduleComponent*) – 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") + + + ### assign\_parameters + + + Assign the parameters in this schedule according to the input. + + **Parameters** + + * **value\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*qiskit.circuit.parameterexpression.ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*Union*](https://docs.python.org/3/library/typing.html#typing.Union "(in Python v3.12)")*\[*[*qiskit.circuit.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 + + + 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 + + + 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 + + + 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 + + + Plot the schedule. + + **Parameters** + + * **style** ([*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*) – 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/stdtypes.html#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/stdtypes.html#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 | 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 + + + 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*) – A list of Callables which take a (int, Union\[‘Schedule’, Instruction]) tuple and return a bool. + * **channels** (*Iterable\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – For example, `[DriveChannel(0), AcquireChannel(0)]`. + * **instruction\_types** (*Iterable\[*[*abc.ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)")*] |* [*abc.ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)")) – For example, `[PulseInstruction, AcquireInstruction]`. + * **time\_ranges** (*Iterable\[*[*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)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | None*) – For example, `[(0, 5), (6, 10)]`. + * **intervals** (*Iterable\[Interval] | 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` instruction. + + **Return type** + + [Schedule](#qiskit.pulse.Schedule "qiskit.pulse.Schedule") + + + ### filter + + + 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*) – A list of Callables which take a (int, Union\[‘Schedule’, Instruction]) tuple and return a bool. + * **channels** (*Iterable\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – For example, `[DriveChannel(0), AcquireChannel(0)]`. + * **instruction\_types** (*Iterable\[*[*abc.ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)")*] |* [*abc.ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)")) – For example, `[PulseInstruction, AcquireInstruction]`. + * **time\_ranges** (*Iterable\[*[*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)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | None*) – For example, `[(0, 5), (6, 10)]`. + * **intervals** (*Iterable\[Interval] | 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` instruction. + + **Return type** + + [Schedule](#qiskit.pulse.Schedule "qiskit.pulse.Schedule") + + + ### get\_parameters + + + 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/stdtypes.html#list "(in Python v3.12)")\[[qiskit.circuit.parameter.Parameter](qiskit.circuit.Parameter "qiskit.circuit.parameter.Parameter")] + + + ### initialize\_from + + + Create new schedule object with metadata of another schedule object. + + **Parameters** + + * **other\_program** (*Any*) – 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") + + + ### insert + + + 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** (*ScheduleComponent*) – 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") + + + ### 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 + + + 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 + + + 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") + + + diff --git a/docs/api/qiskit/1.0/qiskit.pulse.ScheduleBlock.mdx b/docs/api/qiskit/1.0/qiskit.pulse.ScheduleBlock.mdx new file mode 100644 index 00000000000..654caa27b85 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.ScheduleBlock.mdx @@ -0,0 +1,523 @@ +--- +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 + + + 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` 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. + + One way to reference a subroutine in a schedule is to use the pulse builder’s [`reference()`](pulse#qiskit.pulse.builder.reference "qiskit.pulse.builder.reference") function to declare an unassigned reference. In this example, the program is called with the reference key “grand\_child”. You can call a subroutine without specifying a substantial program. + + ```python + from qiskit import pulse + from qiskit.circuit.parameter import Parameter + + amp1 = Parameter("amp1") + amp2 = Parameter("amp2") + + with pulse.build() as sched_inner: + pulse.play(pulse.Constant(100, amp1), pulse.DriveChannel(0)) + + with pulse.build() as sched_outer: + with pulse.align_right(): + pulse.reference("grand_child") + pulse.play(pulse.Constant(200, amp2), pulse.DriveChannel(0)) + ``` + + Now you assign the inner pulse program to this reference. + + ```python + sched_outer.assign_references({("grand_child", ): sched_inner}) + print(sched_outer.parameters) + ``` + + ```python + {Parameter(amp1), Parameter(amp2)} + ``` + + The outer program now has the parameter `amp2` from the inner program, indicating that the inner program’s data has been made available to the outer program. 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(sched_outer.references) + ``` + + ```python + ReferenceManager: + - ('grand_child',): ScheduleBlock(Play(Constant(duration=100, amp=amp1,... + ``` + + 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("amp3") + + with pulse.build() as main: + pulse.play(pulse.Constant(300, amp3), pulse.DriveChannel(0)) + pulse.call(sched_outer, name="child") + + print(main.parameters) + ``` + + ```python + {Parameter(amp1), Parameter(amp2), Parameter(amp3} + ``` + + This implicitly creates a reference named “child” within the root program and assigns `sched_outer` to it. + + 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") still collects 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 + + + + ### 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 + + + + ### references + + + Return a reference manager of the current scope. + + + ## Methods + + ### append + + + 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** (*BlockComponent*) – 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.ScheduleBlock") + + + ### assign\_parameters + + + Assign the parameters in this schedule according to the input. + + **Parameters** + + * **value\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*qiskit.circuit.parameterexpression.ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*Union*](https://docs.python.org/3/library/typing.html#typing.Union "(in Python v3.12)")*\[*[*qiskit.circuit.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 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/stdtypes.html#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/stdtypes.html#tuple "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, ...], '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.ScheduleBlock") + + + ### ch\_duration + + + 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 + + + Plot the schedule. + + **Parameters** + + * **style** ([*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*) – 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/stdtypes.html#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/stdtypes.html#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 | 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 + + + 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** (*Callable\[...,* [*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*]*) – A list of Callables which take a `Instruction` and return a bool. + * **channels** (*Iterable\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – For example, `[DriveChannel(0), AcquireChannel(0)]`. + * **instruction\_types** (*Iterable\[*[*abc.ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)")*] |* [*abc.ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)")) – 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` instruction. + + **Returns** + + `ScheduleBlock` consisting of instructions that do not match with at least one of filtering conditions. + + + ### filter + + + 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** (*Callable\[...,* [*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*]*) – A list of Callables which take a `Instruction` and return a bool. + * **channels** (*Iterable\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – For example, `[DriveChannel(0), AcquireChannel(0)]`. + * **instruction\_types** (*Iterable\[*[*abc.ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)")*] |* [*abc.ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)")) – 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` instruction. + + **Returns** + + `ScheduleBlock` consisting of instructions that matches with filtering condition. + + + ### get\_parameters + + + 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/stdtypes.html#list "(in Python v3.12)")\[[qiskit.circuit.parameter.Parameter](qiskit.circuit.Parameter "qiskit.circuit.parameter.Parameter")] + + + ### initialize\_from + + + Create new schedule object with metadata of another schedule object. + + **Parameters** + + * **other\_program** (*Any*) – 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.ScheduleBlock") + + + ### 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 + + + 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 + + + Return `True` if all durations are assigned. + + **Return type** + + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + ### replace + + + 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") + + + diff --git a/docs/api/qiskit/1.0/qiskit.pulse.channels.AcquireChannel.mdx b/docs/api/qiskit/1.0/qiskit.pulse.channels.AcquireChannel.mdx new file mode 100644 index 00000000000..c113b108e6c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.channels.AcquireChannel.mdx @@ -0,0 +1,60 @@ +--- +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 + + + 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 + + + A shorthand string prefix for characterizing the channel type. + + + ## Methods + + ### 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/1.0/qiskit.pulse.channels.ControlChannel.mdx b/docs/api/qiskit/1.0/qiskit.pulse.channels.ControlChannel.mdx new file mode 100644 index 00000000000..ab52ccf250d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.channels.ControlChannel.mdx @@ -0,0 +1,60 @@ +--- +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 + + + 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 + + + A shorthand string prefix for characterizing the channel type. + + + ## Methods + + ### 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/1.0/qiskit.pulse.channels.DriveChannel.mdx b/docs/api/qiskit/1.0/qiskit.pulse.channels.DriveChannel.mdx new file mode 100644 index 00000000000..c4d03dca138 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.channels.DriveChannel.mdx @@ -0,0 +1,60 @@ +--- +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 + + + 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 + + + A shorthand string prefix for characterizing the channel type. + + + ## Methods + + ### 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/1.0/qiskit.pulse.channels.MeasureChannel.mdx b/docs/api/qiskit/1.0/qiskit.pulse.channels.MeasureChannel.mdx new file mode 100644 index 00000000000..725b2c78e13 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.channels.MeasureChannel.mdx @@ -0,0 +1,60 @@ +--- +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 + + + 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 + + + A shorthand string prefix for characterizing the channel type. + + + ## Methods + + ### 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/1.0/qiskit.pulse.channels.MemorySlot.mdx b/docs/api/qiskit/1.0/qiskit.pulse.channels.MemorySlot.mdx new file mode 100644 index 00000000000..55976dc205e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.channels.MemorySlot.mdx @@ -0,0 +1,60 @@ +--- +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 + + + 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 + + + A shorthand string prefix for characterizing the channel type. + + + ## Methods + + ### 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/1.0/qiskit.pulse.channels.RegisterSlot.mdx b/docs/api/qiskit/1.0/qiskit.pulse.channels.RegisterSlot.mdx new file mode 100644 index 00000000000..63873431818 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.channels.RegisterSlot.mdx @@ -0,0 +1,60 @@ +--- +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 + + + 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 + + + A shorthand string prefix for characterizing the channel type. + + + ## Methods + + ### 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/1.0/qiskit.pulse.channels.SnapshotChannel.mdx b/docs/api/qiskit/1.0/qiskit.pulse.channels.SnapshotChannel.mdx new file mode 100644 index 00000000000..d1f213f0820 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.channels.SnapshotChannel.mdx @@ -0,0 +1,56 @@ +--- +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 + + + 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 + + + A shorthand string prefix for characterizing the channel type. + + + ## Methods + + ### 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/1.0/qiskit.pulse.instructions.Acquire.mdx b/docs/api/qiskit/1.0/qiskit.pulse.instructions.Acquire.mdx new file mode 100644 index 00000000000..81709415b88 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.instructions.Acquire.mdx @@ -0,0 +1,238 @@ +--- +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 + + + 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")) – 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 + + + 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 + + + Return duration of the supplied channels in this Instruction. + + **Parameters** + + **\*channels** ([*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 + + + Return minimum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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 + + + Return maximum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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)") + + + ### insert + + + 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 + + + Return True iff the instruction is parameterized. + + **Return type** + + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + ### shift + + + 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/1.0/qiskit.pulse.instructions.Delay.mdx b/docs/api/qiskit/1.0/qiskit.pulse.instructions.Delay.mdx new file mode 100644 index 00000000000..45464264077 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.instructions.Delay.mdx @@ -0,0 +1,212 @@ +--- +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 + + + 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")) – 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 + + + 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 + + + Return duration of the supplied channels in this Instruction. + + **Parameters** + + **\*channels** ([*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 + + + Return minimum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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 + + + Return maximum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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)") + + + ### insert + + + 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 + + + Return True iff the instruction is parameterized. + + **Return type** + + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + ### shift + + + 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/1.0/qiskit.pulse.instructions.Play.mdx b/docs/api/qiskit/1.0/qiskit.pulse.instructions.Play.mdx new file mode 100644 index 00000000000..3a4f8134192 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.instructions.Play.mdx @@ -0,0 +1,206 @@ +--- +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 + + + 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 + + + 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 + + + Return duration of the supplied channels in this Instruction. + + **Parameters** + + **\*channels** ([*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 + + + Return minimum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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 + + + Return maximum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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)") + + + ### insert + + + 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 + + + Return True iff the instruction is parameterized. + + **Return type** + + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + ### shift + + + 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/1.0/qiskit.pulse.instructions.Reference.mdx b/docs/api/qiskit/1.0/qiskit.pulse.instructions.Reference.mdx new file mode 100644 index 00000000000..79baadefad3 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.instructions.Reference.mdx @@ -0,0 +1,211 @@ +--- +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 + + + 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 + + + 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 + + + Return duration of the supplied channels in this Instruction. + + **Parameters** + + **\*channels** ([*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 + + + Return minimum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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 + + + Return maximum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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)") + + + ### insert + + + 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 + + + Return True iff the instruction is parameterized. + + **Return type** + + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + ### shift + + + 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/1.0/qiskit.pulse.instructions.RelativeBarrier.mdx b/docs/api/qiskit/1.0/qiskit.pulse.instructions.RelativeBarrier.mdx new file mode 100644 index 00000000000..5bcfc1cfa1d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.instructions.RelativeBarrier.mdx @@ -0,0 +1,193 @@ +--- +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 + + + 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** (*chans.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 + + + 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 + + + Return duration of the supplied channels in this Instruction. + + **Parameters** + + **\*channels** ([*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 + + + Return minimum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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 + + + Return maximum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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)") + + + ### insert + + + 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 + + + Return True iff the instruction is parameterized. + + **Return type** + + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + ### shift + + + 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/1.0/qiskit.pulse.instructions.SetFrequency.mdx b/docs/api/qiskit/1.0/qiskit.pulse.instructions.SetFrequency.mdx new file mode 100644 index 00000000000..b4ecd96c119 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.instructions.SetFrequency.mdx @@ -0,0 +1,214 @@ +--- +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 + + + 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 + + + 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 + + + Return duration of the supplied channels in this Instruction. + + **Parameters** + + **\*channels** ([*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 + + + Return minimum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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 + + + Return maximum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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)") + + + ### insert + + + 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 + + + Return True iff the instruction is parameterized. + + **Return type** + + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + ### shift + + + 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/1.0/qiskit.pulse.instructions.SetPhase.mdx b/docs/api/qiskit/1.0/qiskit.pulse.instructions.SetPhase.mdx new file mode 100644 index 00000000000..fa710abf598 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.instructions.SetPhase.mdx @@ -0,0 +1,212 @@ +--- +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 + + + 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 + + + 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 + + + Return duration of the supplied channels in this Instruction. + + **Parameters** + + **\*channels** ([*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 + + + Return minimum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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 + + + Return maximum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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)") + + + ### insert + + + 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 + + + Return True iff the instruction is parameterized. + + **Return type** + + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + ### shift + + + 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/1.0/qiskit.pulse.instructions.ShiftFrequency.mdx b/docs/api/qiskit/1.0/qiskit.pulse.instructions.ShiftFrequency.mdx new file mode 100644 index 00000000000..00e052966fe --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.instructions.ShiftFrequency.mdx @@ -0,0 +1,204 @@ +--- +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 + + + 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 + + + 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 + + + Return duration of the supplied channels in this Instruction. + + **Parameters** + + **\*channels** ([*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 + + + Return minimum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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 + + + Return maximum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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)") + + + ### insert + + + 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 + + + Return True iff the instruction is parameterized. + + **Return type** + + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + ### shift + + + 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/1.0/qiskit.pulse.instructions.ShiftPhase.mdx b/docs/api/qiskit/1.0/qiskit.pulse.instructions.ShiftPhase.mdx new file mode 100644 index 00000000000..777f7af8d63 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.instructions.ShiftPhase.mdx @@ -0,0 +1,216 @@ +--- +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 + + + 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 + + + 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 + + + Return duration of the supplied channels in this Instruction. + + **Parameters** + + **\*channels** ([*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 + + + Return minimum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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 + + + Return maximum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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)") + + + ### insert + + + 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 + + + Return True iff the instruction is parameterized. + + **Return type** + + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + ### shift + + + 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/1.0/qiskit.pulse.instructions.Snapshot.mdx b/docs/api/qiskit/1.0/qiskit.pulse.instructions.Snapshot.mdx new file mode 100644 index 00000000000..16211a6aef3 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.instructions.Snapshot.mdx @@ -0,0 +1,210 @@ +--- +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 + + + 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 + + + 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 + + + Return duration of the supplied channels in this Instruction. + + **Parameters** + + **\*channels** ([*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 + + + Return minimum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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 + + + Return maximum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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)") + + + ### insert + + + 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 + + + Return True iff the instruction is parameterized. + + **Return type** + + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + ### shift + + + 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/1.0/qiskit.pulse.instructions.TimeBlockade.mdx b/docs/api/qiskit/1.0/qiskit.pulse.instructions.TimeBlockade.mdx new file mode 100644 index 00000000000..ef434541f25 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.instructions.TimeBlockade.mdx @@ -0,0 +1,229 @@ +--- +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 + + + 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** (*chans.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 + + + 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 + + + Return duration of the supplied channels in this Instruction. + + **Parameters** + + **\*channels** ([*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 + + + Return minimum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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 + + + Return maximum start time for supplied channels. + + **Parameters** + + **\*channels** ([*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)") + + + ### insert + + + 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 + + + Return True iff the instruction is parameterized. + + **Return type** + + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + ### shift + + + 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/1.0/qiskit.pulse.library.Constant_class.rst.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.Constant_class.rst.mdx new file mode 100644 index 00000000000..334c1914df7 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.Constant_class.rst.mdx @@ -0,0 +1,41 @@ +--- +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 + + + 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. + * **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 + + + + diff --git a/docs/api/qiskit/1.0/qiskit.pulse.library.Cos_class.rst.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.Cos_class.rst.mdx new file mode 100644 index 00000000000..dd046844931 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.Cos_class.rst.mdx @@ -0,0 +1,42 @@ +--- +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 + + + 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")) – 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")) – 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")) – The phase of the cosine wave (note that this is not equivalent to the angle of the complex amplitude). + * **freq** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| 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** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| 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/1.0/qiskit.pulse.library.Drag_class.rst.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.Drag_class.rst.mdx new file mode 100644 index 00000000000..b43c2be2eb6 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.Drag_class.rst.mdx @@ -0,0 +1,57 @@ +--- +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 + + + 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. + * **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 + + + + diff --git a/docs/api/qiskit/1.0/qiskit.pulse.library.GaussianDeriv.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.GaussianDeriv.mdx new file mode 100644 index 00000000000..5bed1103bfe --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.GaussianDeriv.mdx @@ -0,0 +1,42 @@ +--- +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 + + + 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)") *| ParameterValueType*) – 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")) – 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")) – A measure of how wide or narrow the corresponding Gaussian peak is in terms of dt; described mathematically in the class docstring. + * **angle** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| 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/1.0/qiskit.pulse.library.GaussianSquare.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.GaussianSquare.mdx new file mode 100644 index 00000000000..3daf99d2a6d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.GaussianSquare.mdx @@ -0,0 +1,75 @@ +--- +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 + + + 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. + * **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 + + + + diff --git a/docs/api/qiskit/1.0/qiskit.pulse.library.GaussianSquareDrag.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.GaussianSquareDrag.mdx new file mode 100644 index 00000000000..e074fdbc9d1 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.GaussianSquareDrag.mdx @@ -0,0 +1,88 @@ +--- +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 + + + 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")) – 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")) – 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")) – 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")) – The DRAG correction amplitude. + * **width** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| None*) – The duration of the embedded square pulse. + * **angle** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| None*) – The angle in radians of the complex phase factor uniformly scaling the pulse. Default value 0. + * **risefall\_sigma\_ratio** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| 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/1.0/qiskit.pulse.library.Gaussian_class.rst.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.Gaussian_class.rst.mdx new file mode 100644 index 00000000000..b8a79c509e2 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.Gaussian_class.rst.mdx @@ -0,0 +1,46 @@ +--- +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 + + + 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. + * **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 + + + + diff --git a/docs/api/qiskit/1.0/qiskit.pulse.library.Sawtooth_class.rst.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.Sawtooth_class.rst.mdx new file mode 100644 index 00000000000..dc380886562 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.Sawtooth_class.rst.mdx @@ -0,0 +1,43 @@ +--- +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 + + + 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")) – 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")) – 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")) – The phase of the sawtooth wave (note that this is not equivalent to the angle of the complex amplitude) + * **freq** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| 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** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| 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/1.0/qiskit.pulse.library.SechDeriv.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.SechDeriv.mdx new file mode 100644 index 00000000000..5488bf956b3 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.SechDeriv.mdx @@ -0,0 +1,42 @@ +--- +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 + + + 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)") *| ParameterValueType*) – 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")) – 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")) – A measure of how wide or narrow the corresponding sech peak is, in terms of dt; described mathematically in the class docstring. + * **angle** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| 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/1.0/qiskit.pulse.library.Sech_fun.rst.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.Sech_fun.rst.mdx new file mode 100644 index 00000000000..29db9e8de29 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.Sech_fun.rst.mdx @@ -0,0 +1,51 @@ +--- +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 + + + 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)") *| ParameterValueType*) – 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")) – 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")) – A measure of how wide or narrow the sech peak is in terms of dt; described mathematically in the class docstring. + * **angle** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| 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/1.0/qiskit.pulse.library.Sin_class.rst.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.Sin_class.rst.mdx new file mode 100644 index 00000000000..6aa99386ef3 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.Sin_class.rst.mdx @@ -0,0 +1,42 @@ +--- +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 + + + 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")) – 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")) – 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")) – The phase of the sinusoidal wave (note that this is not equivalent to the angle of the complex amplitude) + * **freq** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| 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** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| 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/1.0/qiskit.pulse.library.Square_fun.rst.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.Square_fun.rst.mdx new file mode 100644 index 00000000000..2e3cc3ace02 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.Square_fun.rst.mdx @@ -0,0 +1,43 @@ +--- +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 + + + 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)") *| ParameterValueType*) – 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")) – 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")) – The phase of the square wave (note that this is not equivalent to the angle of the complex amplitude). + * **freq** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| 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** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| 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/1.0/qiskit.pulse.library.SymbolicPulse.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.SymbolicPulse.mdx new file mode 100644 index 00000000000..295f53a5b9b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.SymbolicPulse.mdx @@ -0,0 +1,254 @@ +--- +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 + + + 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. + + **Pulse validation** + + When a symbolic pulse is instantiated, the method [`validate_parameters()`](#qiskit.pulse.library.SymbolicPulse.validate_parameters "qiskit.pulse.library.SymbolicPulse.validate_parameters") is called, and performs validation of the pulse. The validation process involves testing the constraint functions and the maximal amplitude of the pulse (see below). While the validation process will improve code stability, it will reduce performance and might create compatibility issues (particularly with JAX). Therefore, it is possible to disable the validation by setting the class attribute [`disable_validation`](#qiskit.pulse.library.SymbolicPulse.disable_validation "qiskit.pulse.library.SymbolicPulse.disable_validation") to `True`. + + **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/1.0/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") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration of pulse. + * **parameters** (*Mapping\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.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** (*sym.Expr | None*) – Pulse envelope expression. + * **constraints** (*sym.Expr | None*) – Pulse parameter constraint expression. + * **valid\_amp\_conditions** (*sym.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. + + + ### disable\_validation + + + + ### duration + + + + ### envelope + + + Return symbolic expression for the pulse envelope. + + + ### id + + + Unique identifier for this pulse. + + + ### limit\_amplitude + + + + ### name + + + + ### parameters + + + + ### pulse\_type + + + Return display name of the pulse shape. + + + ### valid\_amp\_conditions + + + Return symbolic expression for the pulse amplitude constraints. + + + ## Methods + + ### draw + + + Plot the interpolated envelope of pulse. + + **Parameters** + + * **style** ([*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*) – 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/stdtypes.html#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 | 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 + + + 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 + + + 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. + + **Raises** + + [**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – If the parameters passed are not valid. + + + diff --git a/docs/api/qiskit/1.0/qiskit.pulse.library.Triangle_class.rst.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.Triangle_class.rst.mdx new file mode 100644 index 00000000000..dd8cd915741 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.Triangle_class.rst.mdx @@ -0,0 +1,42 @@ +--- +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 + + + 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")) – 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")) – 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")) – The phase of the triangle wave (note that this is not equivalent to the angle of the complex amplitude) + * **freq** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| 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** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| 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/1.0/qiskit.pulse.library.Waveform.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.Waveform.mdx new file mode 100644 index 00000000000..d0c3eeda34b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.Waveform.mdx @@ -0,0 +1,105 @@ +--- +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 + + + 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** (*np.ndarray |* [*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)")*]*) – 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 + + + + ### parameters + + + Return a dictionary containing the pulse’s parameters. + + + ### samples + + + Return sample values. + + + ## Methods + + ### draw + + + Plot the interpolated envelope of pulse. + + **Parameters** + + * **style** ([*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*) – 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/stdtypes.html#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 | 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 + + + 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/1.0/qiskit.pulse.library.gaussian_square_echo.mdx b/docs/api/qiskit/1.0/qiskit.pulse.library.gaussian_square_echo.mdx new file mode 100644 index 00000000000..9db41ff7b66 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.library.gaussian_square_echo.mdx @@ -0,0 +1,75 @@ +--- +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 + + + 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)") *| ParameterValueType*) – 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")) – 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")) – A measure of how wide or narrow the risefall is; see the class docstring for more details. + * **width** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| None*) – The duration of the embedded square pulse. + * **angle** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| None*) – The angle in radians of the complex phase factor uniformly scaling the echoed pulse. Default value 0. + * **active\_amp** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| None*) – The amplitude of the active pulse. + * **active\_angle** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| None*) – The angle in radian of the complex phase factor uniformly scaling the active pulse. Default value 0. + * **risefall\_sigma\_ratio** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *| 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.SymbolicPulse") + + diff --git a/docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignEquispaced.mdx b/docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignEquispaced.mdx new file mode 100644 index 00000000000..566aeb3e2cf --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignEquispaced.mdx @@ -0,0 +1,58 @@ +--- +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 + + + 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")) – 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 + + + 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/1.0/qiskit.pulse.transforms.AlignFunc.mdx b/docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignFunc.mdx new file mode 100644 index 00000000000..58d736b3947 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignFunc.mdx @@ -0,0 +1,78 @@ +--- +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 + + + 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")) – 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*) – 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 + + + 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/1.0/qiskit.pulse.transforms.AlignLeft.mdx b/docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignLeft.mdx new file mode 100644 index 00000000000..b66860a95c9 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignLeft.mdx @@ -0,0 +1,48 @@ +--- +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 + + + 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 + + + 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/1.0/qiskit.pulse.transforms.AlignRight.mdx b/docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignRight.mdx new file mode 100644 index 00000000000..007abec0f59 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignRight.mdx @@ -0,0 +1,48 @@ +--- +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 + + + 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 + + + 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/1.0/qiskit.pulse.transforms.AlignSequential.mdx b/docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignSequential.mdx new file mode 100644 index 00000000000..8c93fca08d1 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.pulse.transforms.AlignSequential.mdx @@ -0,0 +1,48 @@ +--- +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 + + + 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 + + + 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/1.0/qiskit.qobj.GateCalibration.mdx b/docs/api/qiskit/1.0/qiskit.qobj.GateCalibration.mdx new file mode 100644 index 00000000000..0dde85dcf2f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.GateCalibration.mdx @@ -0,0 +1,59 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.qobj.PulseLibraryItem.mdx b/docs/api/qiskit/1.0/qiskit.qobj.PulseLibraryItem.mdx new file mode 100644 index 00000000000..ec944a5468e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.PulseLibraryItem.mdx @@ -0,0 +1,57 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.qobj.PulseQobj.mdx b/docs/api/qiskit/1.0/qiskit.qobj.PulseQobj.mdx new file mode 100644 index 00000000000..f47ab85e69f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.PulseQobj.mdx @@ -0,0 +1,78 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.qobj.PulseQobjConfig.mdx b/docs/api/qiskit/1.0/qiskit.qobj.PulseQobjConfig.mdx new file mode 100644 index 00000000000..ce4c06815c9 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.PulseQobjConfig.mdx @@ -0,0 +1,67 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.qobj.PulseQobjExperiment.mdx b/docs/api/qiskit/1.0/qiskit.qobj.PulseQobjExperiment.mdx new file mode 100644 index 00000000000..b9a23589bea --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.PulseQobjExperiment.mdx @@ -0,0 +1,60 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.qobj.PulseQobjExperimentConfig.mdx b/docs/api/qiskit/1.0/qiskit.qobj.PulseQobjExperimentConfig.mdx new file mode 100644 index 00000000000..b603d7e3057 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.PulseQobjExperimentConfig.mdx @@ -0,0 +1,58 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.qobj.PulseQobjInstruction.mdx b/docs/api/qiskit/1.0/qiskit.qobj.PulseQobjInstruction.mdx new file mode 100644 index 00000000000..307a36a6763 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.PulseQobjInstruction.mdx @@ -0,0 +1,72 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.qobj.QasmExperimentCalibrations.mdx b/docs/api/qiskit/1.0/qiskit.qobj.QasmExperimentCalibrations.mdx new file mode 100644 index 00000000000..f21c88e7cfe --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.QasmExperimentCalibrations.mdx @@ -0,0 +1,56 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.qobj.QasmQobj.mdx b/docs/api/qiskit/1.0/qiskit.qobj.QasmQobj.mdx new file mode 100644 index 00000000000..73c9e8b994e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.QasmQobj.mdx @@ -0,0 +1,78 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.qobj.QasmQobjConfig.mdx b/docs/api/qiskit/1.0/qiskit.qobj.QasmQobjConfig.mdx new file mode 100644 index 00000000000..c15f0a30f82 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.QasmQobjConfig.mdx @@ -0,0 +1,69 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.qobj.QasmQobjExperiment.mdx b/docs/api/qiskit/1.0/qiskit.qobj.QasmQobjExperiment.mdx new file mode 100644 index 00000000000..bb84c4f6d32 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.QasmQobjExperiment.mdx @@ -0,0 +1,60 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.qobj.QasmQobjExperimentConfig.mdx b/docs/api/qiskit/1.0/qiskit.qobj.QasmQobjExperimentConfig.mdx new file mode 100644 index 00000000000..d3ef90eb5c0 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.QasmQobjExperimentConfig.mdx @@ -0,0 +1,57 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.qobj.QasmQobjInstruction.mdx b/docs/api/qiskit/1.0/qiskit.qobj.QasmQobjInstruction.mdx new file mode 100644 index 00000000000..2d8359bdbb1 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.QasmQobjInstruction.mdx @@ -0,0 +1,67 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.qobj.QobjExperimentHeader.mdx b/docs/api/qiskit/1.0/qiskit.qobj.QobjExperimentHeader.mdx new file mode 100644 index 00000000000..87644c92818 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.QobjExperimentHeader.mdx @@ -0,0 +1,56 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.qobj.QobjHeader.mdx b/docs/api/qiskit/1.0/qiskit.qobj.QobjHeader.mdx new file mode 100644 index 00000000000..4ff4d79cd0e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.QobjHeader.mdx @@ -0,0 +1,56 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.qobj.QobjMeasurementOption.mdx b/docs/api/qiskit/1.0/qiskit.qobj.QobjMeasurementOption.mdx new file mode 100644 index 00000000000..99f81b39402 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.qobj.QobjMeasurementOption.mdx @@ -0,0 +1,57 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.quantum_info.CNOTDihedral.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.CNOTDihedral.mdx new file mode 100644 index 00000000000..2d402d10e39 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.CNOTDihedral.mdx @@ -0,0 +1,327 @@ +--- +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 + + + 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 + + + Return the adjoint of the Operator. + + + ### compose + + + 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 + + + Return the conjugate of the CNOTDihedral. + + + ### copy + + + Make a deep copy of current operator. + + + ### dot + + + 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 + + + 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 + + + Return tuple of input dimension for specified subsystems. + + + ### output\_dims + + + Return tuple of output dimension for specified subsystems. + + + ### power + + + 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 + + + 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 + + + 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 + + + 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 + + + Return a Gate instruction implementing the CNOTDihedral object. + + + ### to\_matrix + + + Convert operator to Numpy matrix. + + + ### to\_operator + + + Convert to an Operator object. + + **Return type** + + [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + + + ### transpose + + + Return the transpose of the CNOTDihedral. + + + diff --git a/docs/api/qiskit/1.0/qiskit.quantum_info.Chi.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.Chi.mdx new file mode 100644 index 00000000000..e5ec426af15 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.Chi.mdx @@ -0,0 +1,353 @@ +--- +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 + + + 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 + + + + ### 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 + + + + ### settings + + + Return settings. + + + ## Methods + + ### 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 + + + 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 + + + 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 + + + Make a deep copy of current operator. + + + ### dot + + + 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 + + + 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 + + + Return tuple of input dimension for specified subsystems. + + + ### is\_cp + + + 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 + + + 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 + + + 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 + + + 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 + + + Return tuple of output dimension for specified subsystems. + + + ### power + + + 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 + + + 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 + + + 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 + + + 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 + + + Try to convert channel to a unitary representation Operator. + + **Return type** + + [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + + + ### 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/1.0/qiskit.quantum_info.Choi.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.Choi.mdx new file mode 100644 index 00000000000..b2b4bcaa09d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.Choi.mdx @@ -0,0 +1,365 @@ +--- +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 + + + 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 + + + + ### 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 + + + + ### settings + + + Return settings. + + + ## Methods + + ### 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 + + + 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 + + + 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 + + + Make a deep copy of current operator. + + + ### dot + + + 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 + + + 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 + + + Return tuple of input dimension for specified subsystems. + + + ### is\_cp + + + 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 + + + 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 + + + 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 + + + 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 + + + Return tuple of output dimension for specified subsystems. + + + ### power + + + 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 + + + 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 + + + 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 + + + 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 + + + Try to convert channel to a unitary representation Operator. + + **Return type** + + [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + + + ### 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/1.0/qiskit.quantum_info.Clifford.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.Clifford.mdx new file mode 100644 index 00000000000..3f8e129564c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.Clifford.mdx @@ -0,0 +1,607 @@ +--- +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 + + + 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 + + + Return the adjoint of the Operator. + + + ### compose + + + 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 + + + Return the conjugate of the Clifford. + + + ### copy + + + Make a deep copy of current operator. + + + ### dot + + + 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 + + + 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 + + + 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 + + + Load a Clifford from a dictionary + + + ### from\_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 + + + 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 + + + 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 + + + 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 + + + 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 + + + Return tuple of input dimension for specified subsystems. + + + ### is\_unitary + + + Return True if the Clifford table is valid. + + + ### output\_dims + + + Return tuple of output dimension for specified subsystems. + + + ### power + + + 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 + + + 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 + + + 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 + + + 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 + + + Return dictionary representation of Clifford object. + + + ### to\_instruction + + + Return a Gate instruction implementing the Clifford. + + + ### to\_labels + + + 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 + + + Convert operator to Numpy matrix. + + + ### to\_operator + + + Convert to an Operator object. + + **Return type** + + [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + + + ### transpose + + + Return the transpose of the Clifford. + + + diff --git a/docs/api/qiskit/1.0/qiskit.quantum_info.DensityMatrix.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.DensityMatrix.mdx new file mode 100644 index 00000000000..c764ed75563 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.DensityMatrix.mdx @@ -0,0 +1,645 @@ +--- +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 + + + 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 + + + + ### data + + + Return data. + + + ### dim + + + Return total state dimension. + + + ### num\_qubits + + + Return the number of qubits if a N-qubit state or None otherwise. + + + ### rtol + + + + ### settings + + + Return settings. + + + ## Methods + + ### conjugate + + + Return the conjugate of the density matrix. + + + ### copy + + + Make a copy of current operator. + + + ### dims + + + Return tuple of input dimension for specified subsystems. + + + ### draw + + + 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 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + Return True if trace 1 and positive semidefinite. + + + ### measure + + + 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 + + + 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 + + + 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 + + + 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 + + + Return the purity of the quantum state. + + + ### reset + + + 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 + + + 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 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 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 + + + Set the seed for the quantum state RNG. + + + ### tensor + + + 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 + + + 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 + + + Convert to Operator + + **Return type** + + [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + + + ### to\_statevector + + + 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 + + + Return the trace of the density matrix. + + + diff --git a/docs/api/qiskit/1.0/qiskit.quantum_info.Kraus.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.Kraus.mdx new file mode 100644 index 00000000000..c9622d711c4 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.Kraus.mdx @@ -0,0 +1,353 @@ +--- +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 + + + 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 + + + + ### 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 + + + + ### settings + + + Return settings. + + + ## Methods + + ### 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 + + + 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 + + + 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 + + + Make a deep copy of current operator. + + + ### dot + + + 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 + + + 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 + + + Return tuple of input dimension for specified subsystems. + + + ### is\_cp + + + 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 + + + Return True if completely-positive trace-preserving. + + + ### is\_tp + + + 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 + + + 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 + + + Return tuple of output dimension for specified subsystems. + + + ### power + + + 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 + + + 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 + + + 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 + + + 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 + + + Try to convert channel to a unitary representation Operator. + + **Return type** + + [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + + + ### 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/1.0/qiskit.quantum_info.Operator.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.Operator.mdx new file mode 100644 index 00000000000..798393e1c6d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.Operator.mdx @@ -0,0 +1,438 @@ +--- +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 + + + 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 + + + + ### 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 + + + + ### settings + + + Return operator settings. + + + ## Methods + + ### adjoint + + + Return the adjoint of the Operator. + + **Return type** + + *Self* + + + ### apply\_permutation + + + 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 + + + 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 + + + Return the conjugate of the Operator. + + + ### copy + + + Make a deep copy of current operator. + + + ### dot + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + Return tuple of input dimension for specified subsystems. + + + ### is\_unitary + + + Return True if operator is a unitary matrix. + + + ### output\_dims + + + Return tuple of output dimension for specified subsystems. + + + ### power + + + 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 + + + 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 + + + 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 + + + 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 + + + Convert to a UnitaryGate instruction. + + + ### to\_matrix + + + Convert operator to NumPy matrix. + + + ### to\_operator + + + Convert operator to matrix operator class + + **Return type** + + [*Operator*](#qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + + + ### transpose + + + Return the transpose of the Operator. + + + diff --git a/docs/api/qiskit/1.0/qiskit.quantum_info.PTM.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.PTM.mdx new file mode 100644 index 00000000000..ceaf46a6031 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.PTM.mdx @@ -0,0 +1,361 @@ +--- +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 + + + 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 + + + + ### 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 + + + + ### settings + + + Return settings. + + + ## Methods + + ### 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 + + + 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 + + + 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 + + + Make a deep copy of current operator. + + + ### dot + + + 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 + + + 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 + + + Return tuple of input dimension for specified subsystems. + + + ### is\_cp + + + 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 + + + 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 + + + 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 + + + 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 + + + Return tuple of output dimension for specified subsystems. + + + ### power + + + 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 + + + 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 + + + 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 + + + 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 + + + Try to convert channel to a unitary representation Operator. + + **Return type** + + [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + + + ### 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/1.0/qiskit.quantum_info.Pauli.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.Pauli.mdx new file mode 100644 index 00000000000..0633ddea9d8 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.Pauli.mdx @@ -0,0 +1,541 @@ +--- +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 + + + 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 + + + Return the adjoint of the Operator. + + + ### anticommutes + + + 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 + + + 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 + + + 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 + + + Return the conjugate of each Pauli in the list. + + + ### copy + + + Make a deep copy of current operator. + + + ### delete + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + Return tuple of input dimension for specified subsystems. + + + ### insert + + + 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 + + + Return the inverse of the Pauli. + + + ### output\_dims + + + Return tuple of output dimension for specified subsystems. + + + ### power + + + 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 + + + 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 + + + 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 + + + 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 + + + Convert to Pauli circuit instruction. + + + ### 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 + + + 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 + + + Return the transpose of each Pauli in the list. + + + diff --git a/docs/api/qiskit/1.0/qiskit.quantum_info.PauliList.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.PauliList.mdx new file mode 100644 index 00000000000..ee0458aea6f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.PauliList.mdx @@ -0,0 +1,801 @@ +--- +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 + + + 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 + + + Return the adjoint of each Pauli in the list. + + + ### anticommutes + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + Return the conjugate of each Pauli in the list. + + + ### copy + + + Make a deep copy of current operator. + + + ### delete + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + Return tuple of input dimension for specified subsystems. + + + ### insert + + + 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 + + + Return the inverse of each Pauli in the list. + + + ### 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 + + + 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 + + + Return tuple of output dimension for specified subsystems. + + + ### power + + + 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 + + + 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 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 + + + 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 + + + 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 + + + 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 + + + Return the transpose of each Pauli in the list. + + + ### unique + + + 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/1.0/qiskit.quantum_info.Quaternion.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.Quaternion.mdx new file mode 100644 index 00000000000..a29535d7e7e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.Quaternion.mdx @@ -0,0 +1,112 @@ +--- +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 + + + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + + A class representing a Quaternion. + + ## Methods + + ### from\_axis\_rotation + + + 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 + + + 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 of quaternion. + + + ### normalize + + + 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 + + + Converts a unit-length quaternion to a rotation matrix. + + **Returns** + + Rotation matrix. + + **Return type** + + ndarray + + + ### 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/1.0/qiskit.quantum_info.ScalarOp.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.ScalarOp.mdx new file mode 100644 index 00000000000..40c52df5738 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.ScalarOp.mdx @@ -0,0 +1,266 @@ +--- +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 + + + 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 + + + + ### 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 + + + + ## Methods + + ### adjoint + + + Return the adjoint of the Operator. + + **Return type** + + *Self* + + + ### compose + + + 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 + + + Return the conjugate of the ScalarOp. + + + ### copy + + + Make a deep copy of current operator. + + + ### dot + + + 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 + + + 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 + + + Return tuple of input dimension for specified subsystems. + + + ### is\_unitary + + + Return True if operator is a unitary matrix. + + + ### output\_dims + + + Return tuple of output dimension for specified subsystems. + + + ### power + + + 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 + + + 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 + + + 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 + + + Convert to a Numpy matrix. + + + ### to\_operator + + + Convert to an Operator object. + + **Return type** + + [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + + + ### transpose + + + Return the transpose of the ScalarOp. + + + diff --git a/docs/api/qiskit/1.0/qiskit.quantum_info.SparsePauliOp.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.SparsePauliOp.mdx new file mode 100644 index 00000000000..cc1f667ab98 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.SparsePauliOp.mdx @@ -0,0 +1,817 @@ +--- +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 + + + 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 + + + + ### 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 + + + + ### settings + + + Return settings. + + + ### size + + + The number of Pauli of Pauli terms in the operator. + + + ## Methods + + ### adjoint + + + Return the adjoint of the Operator. + + + ### apply\_layout + + + 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)")*] | None*) – Either a [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout"), a list of integers or None. If both layout and num\_qubits are none, a copy of the operator is returned. + * **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. If layout is None, the operator will be expanded to the given number of qubits. + + **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 + + + 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 + + + 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 + + + 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 + + + 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 + + + Return the conjugate of the SparsePauliOp. + + + ### copy + + + Make a deep copy of current operator. + + + ### dot + + + 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 + + + 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 + + + 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 + + + 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 + + + Construct from an Operator objector. + + Note that the cost of this construction is exponential in general because the number of possible Pauli terms in the decomposition is exponential in the number of qubits. + + Internally this uses an implementation of the “tensorized Pauli decomposition” presented in [Hantzko, Binkowski and Gupta (2023)](https://arxiv.org/abs/2310.13421). + + **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). Since the comparison is to zero, in effect the tolerance used is the maximum of `atol` and `rtol`. + * **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). Since the comparison is to zero, in effect the tolerance used is the maximum of `atol` and `rtol`. + + **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 + + + 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 + + + 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 + + + Return tuple of input dimension for specified subsystems. + + + ### is\_unitary + + + 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 + + + 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 + + + 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 + + + Return tuple of output dimension for specified subsystems. + + + ### power + + + 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 + + + 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 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 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + Convert to a matrix Operator object + + **Return type** + + [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + + + ### transpose + + + Return the transpose of the SparsePauliOp. + + + diff --git a/docs/api/qiskit/1.0/qiskit.quantum_info.StabilizerState.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.StabilizerState.mdx new file mode 100644 index 00000000000..fc92d9295e9 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.StabilizerState.mdx @@ -0,0 +1,427 @@ +--- +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 + + + 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 + ``` + + Given a list of stabilizers, [`qiskit.quantum_info.StabilizerState.from_stabilizer_list()`](#qiskit.quantum_info.StabilizerState.from_stabilizer_list "qiskit.quantum_info.StabilizerState.from_stabilizer_list") returns a state stabilized by the list + + ```python + from qiskit.quantum_info import StabilizerState + + stabilizer_list = ["ZXX", "-XYX", "+ZYY"] + stab = StabilizerState.from_stabilizer_list(stabilizer_list) + ``` + + **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 + + + Return the conjugate of the operator. + + + ### copy + + + Make a copy of current operator. + + + ### dims + + + Return tuple of input dimension for specified subsystems. + + + ### equiv + + + 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 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 + + + 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 + + + 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. + + + ### from\_stabilizer\_list + + + Create a stabilizer state from the collection of stabilizers. + + **Parameters** + + * **stabilizers** (*Collection\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – list of stabilizer strings + * **allow\_redundant** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – allow redundant stabilizers (i.e., some stabilizers can be products of the others) + * **allow\_underconstrained** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – allow underconstrained set of stabilizers (i.e., the stabilizers do not specify a unique state) + + **Returns** + + a state stabilized by stabilizers. + + **Return type** + + [StabilizerState](#qiskit.quantum_info.StabilizerState "qiskit.quantum_info.StabilizerState") + + + ### is\_valid + + + Return True if a valid StabilizerState. + + + ### measure + + + 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 + + + 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 + + + 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 + + + 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 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 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 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 + + + Set the seed for the quantum state RNG. + + + ### tensor + + + 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 + + + Convert state to matrix operator class + + **Return type** + + [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + + + ### 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/1.0/qiskit.quantum_info.Statevector.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.Statevector.mdx new file mode 100644 index 00000000000..12eb5f8b4ac --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.Statevector.mdx @@ -0,0 +1,674 @@ +--- +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 + + + 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 + + + + ### data + + + Return data. + + + ### dim + + + Return total state dimension. + + + ### num\_qubits + + + Return the number of qubits if a N-qubit state or None otherwise. + + + ### rtol + + + + ### settings + + + Return settings. + + + ## Methods + + ### conjugate + + + Return the conjugate of the operator. + + **Return type** + + [*Statevector*](#qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") + + + ### copy + + + Make a copy of current operator. + + + ### dims + + + Return tuple of input dimension for specified subsystems. + + + ### draw + + + 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/1.0/qiskit-quantum_info-Statevector-1.png) + + + ### equiv + + + 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 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 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 + + + 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 + + + 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 + + + Return the purity of the quantum state. + + **Return type** + + *float64* + + + ### reset + + + 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 + + + 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 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 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 + + + Set the seed for the quantum state RNG. + + + ### tensor + + + 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 + + + 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 + + + Convert state to a rank-1 projector operator + + **Return type** + + [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + + + ### trace + + + Return the trace of the quantum state as a density matrix. + + **Return type** + + *float64* + + + diff --git a/docs/api/qiskit/1.0/qiskit.quantum_info.Stinespring.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.Stinespring.mdx new file mode 100644 index 00000000000..bcf8b23d6fe --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.Stinespring.mdx @@ -0,0 +1,357 @@ +--- +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 + + + 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 + + + + ### 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 + + + + ### settings + + + Return settings. + + + ## Methods + + ### 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 + + + 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 + + + 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 + + + Make a deep copy of current operator. + + + ### dot + + + 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 + + + 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 + + + Return tuple of input dimension for specified subsystems. + + + ### is\_cp + + + 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 + + + Return True if completely-positive trace-preserving. + + + ### is\_tp + + + 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 + + + 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 + + + Return tuple of output dimension for specified subsystems. + + + ### power + + + 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 + + + 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 + + + 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 + + + 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 + + + Try to convert channel to a unitary representation Operator. + + **Return type** + + [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + + + ### 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/1.0/qiskit.quantum_info.SuperOp.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.SuperOp.mdx new file mode 100644 index 00000000000..c9b71d37222 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.SuperOp.mdx @@ -0,0 +1,353 @@ +--- +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 + + + 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 + + + + ### 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 + + + + ### settings + + + Return settings. + + + ## Methods + + ### 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 + + + 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 + + + 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 + + + Make a deep copy of current operator. + + + ### dot + + + 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 + + + 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 + + + Return tuple of input dimension for specified subsystems. + + + ### is\_cp + + + 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 + + + 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 + + + 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 + + + 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 + + + Return tuple of output dimension for specified subsystems. + + + ### power + + + 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 + + + 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 + + + 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 + + + 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 + + + Try to convert channel to a unitary representation Operator. + + **Return type** + + [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + + + ### 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/1.0/qiskit.quantum_info.Z2Symmetries.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.Z2Symmetries.mdx new file mode 100644 index 00000000000..a472c14dd73 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.Z2Symmetries.mdx @@ -0,0 +1,180 @@ +--- +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 + + + 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 + + + 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 + + + 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 + + + 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 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 + + + 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/1.0/qiskit.quantum_info.pauli_basis.mdx b/docs/api/qiskit/1.0/qiskit.quantum_info.pauli_basis.mdx new file mode 100644 index 00000000000..df2e64e73ec --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.quantum_info.pauli_basis.mdx @@ -0,0 +1,29 @@ +--- +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 + + + 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/1.0/qiskit.result.BaseReadoutMitigator.mdx b/docs/api/qiskit/1.0/qiskit.result.BaseReadoutMitigator.mdx new file mode 100644 index 00000000000..c494731b95e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.result.BaseReadoutMitigator.mdx @@ -0,0 +1,63 @@ +--- +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 + + + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + + Base readout error mitigator class. + + ## Methods + + ### expectation\_value + + + 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 + + + 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/1.0/qiskit.result.CorrelatedReadoutMitigator.mdx b/docs/api/qiskit/1.0/qiskit.result.CorrelatedReadoutMitigator.mdx new file mode 100644 index 00000000000..d2f7696ea1e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.result.CorrelatedReadoutMitigator.mdx @@ -0,0 +1,154 @@ +--- +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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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/1.0/qiskit.result.Counts.mdx b/docs/api/qiskit/1.0/qiskit.result.Counts.mdx new file mode 100644 index 00000000000..0a7996d0419 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.result.Counts.mdx @@ -0,0 +1,170 @@ +--- +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 + + + 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 + + + + ## Methods + + ### clear + + + + ### copy + + + + ### fromkeys + + + Create a new dictionary with keys from iterable and values set to value. + + + ### get + + + Return the value for key if key is in the dictionary, else default. + + + ### 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 + + + 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 + + + + ### keys + + + + ### 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 + + + If key is not found, default is returned if given, otherwise KeyError is raised + + + ### 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 + + + 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 + + + Return the number of shots + + + ### update + + + 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 + + + + diff --git a/docs/api/qiskit/1.0/qiskit.result.LocalReadoutMitigator.mdx b/docs/api/qiskit/1.0/qiskit.result.LocalReadoutMitigator.mdx new file mode 100644 index 00000000000..cce1a33d073 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.result.LocalReadoutMitigator.mdx @@ -0,0 +1,160 @@ +--- +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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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/1.0/qiskit.result.ProbDistribution.mdx b/docs/api/qiskit/1.0/qiskit.result.ProbDistribution.mdx new file mode 100644 index 00000000000..7a1b0ee770c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.result.ProbDistribution.mdx @@ -0,0 +1,133 @@ +--- +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 + + + 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 + + + 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 + + + + ### copy + + + + ### fromkeys + + + Create a new dictionary with keys from iterable and values set to value. + + + ### get + + + Return the value for key if key is in the dictionary, else default. + + + ### 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 + + + + ### keys + + + + ### pop + + + If key is not found, default is returned if given, otherwise KeyError is raised + + + ### 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 + + + 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 + + + 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 + + + + diff --git a/docs/api/qiskit/1.0/qiskit.result.QuasiDistribution.mdx b/docs/api/qiskit/1.0/qiskit.result.QuasiDistribution.mdx new file mode 100644 index 00000000000..b89782f5a0e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.result.QuasiDistribution.mdx @@ -0,0 +1,169 @@ +--- +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 + + + 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 + + + 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 + + + + ### copy + + + + ### fromkeys + + + Create a new dictionary with keys from iterable and values set to value. + + + ### get + + + Return the value for key if key is in the dictionary, else default. + + + ### 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 + + + + ### keys + + + + ### nearest\_probability\_distribution + + + 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 + + + If key is not found, default is returned if given, otherwise KeyError is raised + + + ### 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 + + + 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 + + + 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 + + + + diff --git a/docs/api/qiskit/1.0/qiskit.result.Result.mdx b/docs/api/qiskit/1.0/qiskit.result.Result.mdx new file mode 100644 index 00000000000..c9d3932d32a --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.result.Result.mdx @@ -0,0 +1,242 @@ +--- +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 + + + 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 + + + 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 + + + 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 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 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 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 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 + + + 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/1.0/qiskit.result.ResultError.mdx b/docs/api/qiskit/1.0/qiskit.result.ResultError.mdx new file mode 100644 index 00000000000..566cddb830a --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.result.ResultError.mdx @@ -0,0 +1,32 @@ +--- +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 + + + 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/1.0/qiskit.synthesis.EvolutionSynthesis.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.EvolutionSynthesis.mdx new file mode 100644 index 00000000000..6ad1bd61648 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.EvolutionSynthesis.mdx @@ -0,0 +1,52 @@ +--- +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 + + + 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 + + + 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/1.0/qiskit.synthesis.LieTrotter.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.LieTrotter.mdx new file mode 100644 index 00000000000..e35bf1e1c97 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.LieTrotter.mdx @@ -0,0 +1,75 @@ +--- +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 + + + 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 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/1.0/qiskit.synthesis.MatrixExponential.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.MatrixExponential.mdx new file mode 100644 index 00000000000..c133654f102 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.MatrixExponential.mdx @@ -0,0 +1,54 @@ +--- +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 + + + 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 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/1.0/qiskit.synthesis.OneQubitEulerDecomposer.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.OneQubitEulerDecomposer.mdx new file mode 100644 index 00000000000..17ab8378a48 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.OneQubitEulerDecomposer.mdx @@ -0,0 +1,122 @@ +--- +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 + + + 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)$ | + + ### \_\_call\_\_ + + + Decompose single qubit gate into a circuit. + + **Parameters** + + * **unitary** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") *|*[*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate") *| np.ndarray*) – 1-qubit unitary matrix + * **simplify** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – reduce gate count in decomposition \[Default: True]. + * **atol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – absolute tolerance for checking angles when simplifying returned circuit \[Default: 1e-12]. + + **Returns** + + the decomposed single-qubit gate circuit + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + **Raises** + + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input is invalid or synthesis fails. + + + 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 + + + Return the Euler angles for input array. + + **Parameters** + + **unitary** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – $2\times2$ 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 + + + Return the Euler angles and phase for input array. + + **Parameters** + + **unitary** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – $2\times2$ + + **Returns** + + `(theta, phi, lambda, phase)`. + + **Return type** + + [tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") + + + ### build\_circuit + + + Return the circuit or dag object from a list of gates. + + + diff --git a/docs/api/qiskit/1.0/qiskit.synthesis.ProductFormula.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.ProductFormula.mdx new file mode 100644 index 00000000000..21e886eb463 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.ProductFormula.mdx @@ -0,0 +1,62 @@ +--- +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 + + + 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 + + + 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/1.0/qiskit.synthesis.QDrift.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.QDrift.mdx new file mode 100644 index 00000000000..e021f71b94b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.QDrift.mdx @@ -0,0 +1,64 @@ +--- +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 + + + 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 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/1.0/qiskit.synthesis.SolovayKitaevDecomposition.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.SolovayKitaevDecomposition.mdx new file mode 100644 index 00000000000..238e093333f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.SolovayKitaevDecomposition.mdx @@ -0,0 +1,85 @@ +--- +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 + + + 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 + + + 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. + + **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 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/1.0/qiskit.synthesis.SuzukiTrotter.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.SuzukiTrotter.mdx new file mode 100644 index 00000000000..bd45acceb85 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.SuzukiTrotter.mdx @@ -0,0 +1,82 @@ +--- +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 + + + 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 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/1.0/qiskit.synthesis.TwoQubitBasisDecomposer.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.TwoQubitBasisDecomposer.mdx new file mode 100644 index 00000000000..f79e68b0e66 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.TwoQubitBasisDecomposer.mdx @@ -0,0 +1,108 @@ +--- +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 + + + 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. Defaults to `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`](qiskit.synthesis.OneQubitEulerDecomposer "qiskit.synthesis.OneQubitEulerDecomposer") for 1Q synthesis. Valid options are \[`'ZYZ'`, `'ZXZ'`, `'XYX'`, `'U'`, `'U3'`, `'U1X'`, `'PSX'`, `'ZSX'`, `'RR'`]. + * **pulse\_optimize** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – 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. + + ### \_\_call\_\_ + + + Decompose a two-qubit `unitary` over fixed basis and $SU(2)$ using the best approximation given that each basis application has a finite `basis_fidelity`. + + **Parameters** + + * **unitary** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") *or ndarray*) – $4 \times 4$ unitary to synthesize. + * **basis\_fidelity** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *or None*) – Fidelity to be assumed for applications of KAK Gate. If given, overrides `basis_fidelity` given at init. + * **approximate** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Approximates if basis fidelities are less than 1.0. + * **\_num\_basis\_uses** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – force a particular approximation by passing a number in \[0, 3]. + + **Returns** + + Synthesized quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + **Raises** + + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if `pulse_optimize` is True but we don’t know how to do it. + + + ## Methods + + ### decomp0 + + + Decompose target $\sim U_d(x, y, z)$ with $0$ uses of the basis gate. Result $U_r$ has trace: + +$$ +\Big\vert\text{Tr}(U_r\cdot U_\text{target}^{\dag})\Big\vert = +4\Big\vert (\cos(x)\cos(y)\cos(z)+ j \sin(x)\sin(y)\sin(z)\Big\vert +$$ + + which is optimal for all targets and bases + + + ### decomp1 + + + Decompose target $\sim U_d(x, y, z)$ with $1$ use of the basis gate $\sim U_d(a, b, c)$. Result $U_r$ has trace: + +$$ +\Big\vert\text{Tr}(U_r \cdot U_\text{target}^{\dag})\Big\vert = +4\Big\vert \cos(x-a)\cos(y-b)\cos(z-c) + j \sin(x-a)\sin(y-b)\sin(z-c)\Big\vert +$$ + + which is optimal for all targets and bases with `z==0` or `c==0`. + + + ### decomp2\_supercontrolled + + + Decompose target $\sim U_d(x, y, z)$ with $2$ uses of the basis gate. + + For supercontrolled basis $\sim U_d(\pi/4, b, 0)$, all b, result $U_r$ has trace + +$$ +\Big\vert\text{Tr}(U_r \cdot U_\text{target}^\dag) \Big\vert = 4\cos(z) +$$ + + which is the optimal approximation for basis of CNOT-class $\sim U_d(\pi/4, 0, 0)$ or DCNOT-class $\sim U_d(\pi/4, \pi/4, 0)$ and any target. It may be sub-optimal for $b \neq 0$ (i.e. there exists an exact decomposition for any target using $B \sim U_d(\pi/4, \pi/8, 0)$, but it may not be this decomposition). This is an exact decomposition for supercontrolled basis and target $\sim U_d(x, y, 0)$. No guarantees for non-supercontrolled basis. + + + ### decomp3\_supercontrolled + + + Decompose target with $3$ uses of the basis. This is an exact decomposition for supercontrolled basis $\sim U_d(\pi/4, b, 0)$, all b, and any target. No guarantees for non-supercontrolled basis. + + + ### num\_basis\_gates + + + Computes the number of basis gates needed in a decomposition of input unitary + + + ### traces + + + Give the expected traces $\Big\vert\text{Tr}(U \cdot U_\text{target}^{\dag})\Big\vert$ for a different number of basis gates. + + + diff --git a/docs/api/qiskit/1.0/qiskit.synthesis.TwoQubitWeylDecomposition.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.TwoQubitWeylDecomposition.mdx new file mode 100644 index 00000000000..19893280f59 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.TwoQubitWeylDecomposition.mdx @@ -0,0 +1,134 @@ +--- +title: TwoQubitWeylDecomposition +description: API reference for qiskit.synthesis.TwoQubitWeylDecomposition +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.TwoQubitWeylDecomposition +--- + +# TwoQubitWeylDecomposition + + + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + + Two-qubit Weyl decomposition. + + Decompose two-qubit unitary + +$$ +U = ({K_1}^l \otimes {K_1}^r) e^{(i a XX + i b YY + i c ZZ)} ({K_2}^l \otimes {K_2}^r) +$$ + + where + +$$ +U \in U(4),~ +{K_1}^l, {K_1}^r, {K_2}^l, {K_2}^r \in SU(2) +$$ + + and we stay in the “Weyl Chamber” + +$$ +\pi /4 \geq a \geq b \geq |c| +$$ + + This is an abstract factory class that instantiates itself as specialized subclasses based on the fidelity, such that the approximation error from specialization has an average gate fidelity at least as high as requested. The specialized subclasses have unique canonical representations thus avoiding problems of numerical stability. + + Passing non-None fidelity to specializations is treated as an assertion, raising QiskitError if forcing the specialization is more approximate than asserted. + + **References** + + 1. Cross, A. W., Bishop, L. S., Sheldon, S., Nation, P. D. & Gambetta, J. M., *Validating quantum computers using randomized model circuits*, [arXiv:1811.12926 \[quant-ph\]](https://arxiv.org/abs/1811.12926) + 2. B. Kraus, J. I. Cirac, *Optimal Creation of Entanglement Using a Two-Qubit Gate*, [arXiv:0011050 \[quant-ph\]](https://arxiv.org/abs/quant-ph/0011050) + 3. B. Drury, P. J. Love, *Constructive Quantum Shannon Decomposition from Cartan Involutions*, [arXiv:0806.4015 \[quant-ph\]](https://arxiv.org/abs/0806.4015) + + **Parameters** + + * **unitary\_matrix** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – The unitary to decompose. + * **fidelity** – The target fidelity of the decomposed operation. + + ## Attributes + + ### a + + + + ### b + + + + ### c + + + + ### global\_phase + + + + ### K1l + + + + ### K2l + + + + ### K1r + + + + ### K2r + + + + ### unitary\_matrix + + + + ### requested\_fidelity + + + + ### calculated\_fidelity + + + + ## Methods + + ### actual\_fidelity + + + Calculates the actual fidelity of the decomposed circuit to the input unitary. + + **Return type** + + [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + + + ### circuit + + + Returns Weyl decomposition in circuit form. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + + ### from\_bytes + + + Decode bytes into [`TwoQubitWeylDecomposition`](#qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.TwoQubitWeylDecomposition"). + + **Return type** + + [*TwoQubitWeylDecomposition*](#qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.two_qubit.two_qubit_decompose.TwoQubitWeylDecomposition") + + + ### specialize + + + Make changes to the decomposition to comply with any specialization. + + + diff --git a/docs/api/qiskit/1.0/qiskit.synthesis.XXDecomposer.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.XXDecomposer.mdx new file mode 100644 index 00000000000..ff52d7fe9dd --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.XXDecomposer.mdx @@ -0,0 +1,59 @@ +--- +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 + + + 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`](qiskit.synthesis.OneQubitEulerDecomposer "qiskit.synthesis.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 [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate"). + * **backup\_optimizer** (*Callable\[...,* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*] | None*) – If supplied, defers synthesis to this callable when [`XXDecomposer`](#qiskit.synthesis.XXDecomposer "qiskit.synthesis.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`. + + + ### \_\_call\_\_ + + + Fashions a circuit which (perhaps approximately) models the special unitary operation `unitary`, using the circuit templates supplied at initialization as `embodiments`. The routine uses `basis_fidelity` to select the optimal circuit template, including when performing exact synthesis; the contents of `basis_fidelity` is a dictionary mapping interaction strengths (scaled so that $CX = RZX(\pi/2)$ corresponds to $\pi/2$) to circuit fidelities. + + **Parameters** + + * **unitary** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") *or ndarray*) – $4 \times 4$ unitary to synthesize. + * **basis\_fidelity** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *or*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Fidelity of basis gates. 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}`. If given, overrides the basis\_fidelity given at init. + * **approximate** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Approximates if basis fidelities are less than 1.0 . + + **Returns** + + Synthesized circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + + ## Methods + + ### num\_basis\_gates + + + Counts the number of gates that would be emitted during re-synthesis. + + + This method is used by [`ConsolidateBlocks`](qiskit.transpiler.passes.ConsolidateBlocks "qiskit.transpiler.passes.ConsolidateBlocks"). + + + + diff --git a/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.AQC.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.AQC.mdx new file mode 100644 index 00000000000..de001455679 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.AQC.mdx @@ -0,0 +1,41 @@ +--- +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 + + + 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` 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. + + **Parameters** + + * **optimizer** (*Minimizer | 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 + + + 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/1.0/qiskit.synthesis.unitary.aqc.ApproximateCircuit.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.ApproximateCircuit.mdx new file mode 100644 index 00000000000..fe8ed3268f1 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.ApproximateCircuit.mdx @@ -0,0 +1,217 @@ +--- +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 + + + 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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### 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 + + + **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/1.0/qiskit.synthesis.unitary.aqc.ApproximatingObjective.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.ApproximatingObjective.mdx new file mode 100644 index 00000000000..d81eb8d8a18 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.ApproximatingObjective.mdx @@ -0,0 +1,68 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.mdx new file mode 100644 index 00000000000..483ae5db9ca --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.mdx @@ -0,0 +1,219 @@ +--- +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 + + + 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 + + + ### global\_phase + + + Return the global phase of the current circuit scope in radians. + + + ### instances + + + + ### 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 + >>> 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 + + + + ### 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 + + + **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/1.0/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.mdx new file mode 100644 index 00000000000..5e5c2a3dcfa --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.mdx @@ -0,0 +1,41 @@ +--- +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 + + + 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/1.0/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.mdx new file mode 100644 index 00000000000..434eaed69ac --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.mdx @@ -0,0 +1,79 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.mdx new file mode 100644 index 00000000000..404ef337a7a --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.mdx @@ -0,0 +1,63 @@ +--- +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 + + + 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 + + + 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 + + + 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/1.0/qiskit.synthesis.unitary.aqc.mdx b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.mdx new file mode 100644 index 00000000000..af1b2d69e5d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.synthesis.unitary.aqc.mdx @@ -0,0 +1,168 @@ +--- +title: aqc +description: API reference for qiskit.synthesis.unitary.aqc +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit.synthesis.unitary.aqc +--- + + + + + +# 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 + + + 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/1.0/qiskit.transpiler.AnalysisPass.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.AnalysisPass.mdx new file mode 100644 index 00000000000..830a039a689 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.AnalysisPass.mdx @@ -0,0 +1,99 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.CouplingMap.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.CouplingMap.mdx new file mode 100644 index 00000000000..5a29b1e165b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.CouplingMap.mdx @@ -0,0 +1,382 @@ +--- +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 + + + 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 directed edge to coupling graph. + + src (int): source physical qubit dst (int): destination physical qubit + + + ### add\_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 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 + + + 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 + + + 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 + + + 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)") 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 + + + Return a fully connected coupling map on n qubits. + + **Return type** + + [*CouplingMap*](#qiskit.transpiler.CouplingMap "qiskit.transpiler.coupling.CouplingMap") + + + ### from\_grid + + + 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 + + + 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 + + + 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 + + + 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 + + + Return a coupling map of n qubits connected in a line. + + **Return type** + + [*CouplingMap*](#qiskit.transpiler.CouplingMap "qiskit.transpiler.coupling.CouplingMap") + + + ### from\_ring + + + 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 + + + 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 + + + Test if the graph is connected. + + Return True if connected, False otherwise + + + ### largest\_connected\_component + + + Return a set of qubits in the largest connected component. + + + ### make\_symmetric + + + Convert uni-directional edges into bi-directional. + + + ### neighbors + + + 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 + + + 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 + + + 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 + + + Return the number of physical qubits in this graph. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.InstructionDurations.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.InstructionDurations.mdx new file mode 100644 index 00000000000..432804c6aac --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.InstructionDurations.mdx @@ -0,0 +1,106 @@ +--- +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 + + + 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 + + + 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 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 + + + 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 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/1.0/qiskit.transpiler.InstructionProperties.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.InstructionProperties.mdx new file mode 100644 index 00000000000..762e5d9907c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.InstructionProperties.mdx @@ -0,0 +1,50 @@ +--- +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 + + + 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/1.0/qiskit.transpiler.Layout.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.Layout.mdx new file mode 100644 index 00000000000..74bef73eb59 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.Layout.mdx @@ -0,0 +1,237 @@ +--- +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 + + + 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 + + + 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 + + + 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 + + + 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 + + + Returns a copy of a Layout instance. + + + ### from\_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 + + + 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 + + + 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 + + + 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 + + + Returns the dictionary where the keys are physical (qu)bits and the values are virtual (qu)bits. + + + ### 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 + + + Returns the dictionary where the keys are virtual (qu)bits and the values are physical (qu)bits. + + + ### order\_based\_on\_type + + + decides which one is physical/virtual based on the type. Returns (virtual, physical) + + + ### reorder\_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 + + + 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/1.0/qiskit.transpiler.PassManager.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.PassManager.mdx new file mode 100644 index 00000000000..ae3f37121ad --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.PassManager.mdx @@ -0,0 +1,156 @@ +--- +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 + + + 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 a Pass Set to the schedule of passes. + + **Parameters** + + **passes** (*Task |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[Task]*) – A set of transpiler passes to be added to schedule. + + **Raises** + + [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if a pass in passes is not a proper pass. + + + ### draw + + + 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. + + + ### remove + + + 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 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 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. + + + ### run + + + 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'] + ... + ``` + + * **num\_processes** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of parallel processes to launch if parallel execution is enabled. This argument overrides `num_processes` in the user configuration file, and the `QISKIT_NUM_PROCS` environment variable. If set to `None` the system default or local user configuration will be used. + + **Returns** + + The transformed circuit(s). + + **Return type** + + \_CircuitsT + + + ### 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/1.0/qiskit.transpiler.PassManagerConfig.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.PassManagerConfig.mdx new file mode 100644 index 00000000000..d0ffb2418cf --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.PassManagerConfig.mdx @@ -0,0 +1,66 @@ +--- +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 + + + 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*](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.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 + + + 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/1.0/qiskit.transpiler.StagedPassManager.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.StagedPassManager.mdx new file mode 100644 index 00000000000..ab6fa27e6ac --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.StagedPassManager.mdx @@ -0,0 +1,176 @@ +--- +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 + + + 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 + + + + ### stages + + + Pass manager stages + + + ## Methods + + ### append + + + Append a Pass Set to the schedule of passes. + + **Parameters** + + **passes** (*Task |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[Task]*) – A set of transpiler passes to be added to schedule. + + **Raises** + + [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if a pass in passes is not a proper pass. + + + ### draw + + + Draw the staged pass manager. + + + ### remove + + + 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 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 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. + + + ### run + + + 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'] + ... + ``` + + * **num\_processes** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of parallel processes to launch if parallel execution is enabled. This argument overrides `num_processes` in the user configuration file, and the `QISKIT_NUM_PROCS` environment variable. If set to `None` the system default or local user configuration will be used. + + **Returns** + + The transformed circuit(s). + + **Return type** + + \_CircuitsT + + + ### 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/1.0/qiskit.transpiler.Target.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.Target.mdx new file mode 100644 index 00000000000..6feb56ad759 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.Target.mdx @@ -0,0 +1,591 @@ +--- +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 + + + 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 + + **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 + + + + ### 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 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** (*Union\[*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")*,* [*Type*](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type")*\[*[*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 + + + 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 + + + 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 + + + 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\_calibration + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + + ### keys + + + + ### operation\_from\_name + + + 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 + + + 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 + + + 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 + + + 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 + + + Get an `TimingConstraints` object from the target + + **Returns** + + The timing constraints represented in the `Target` + + **Return type** + + TimingConstraints + + + ### update\_from\_instruction\_schedule\_map + + + 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 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 + + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.TransformationPass.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.TransformationPass.mdx new file mode 100644 index 00000000000..07de131e730 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.TransformationPass.mdx @@ -0,0 +1,99 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.TranspileLayout.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.TranspileLayout.mdx new file mode 100644 index 00000000000..e7b03796dcd --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.TranspileLayout.mdx @@ -0,0 +1,214 @@ +--- +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 + + + 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 + + + + ### initial\_layout + + + + ### input\_qubit\_mapping + + + + ## Methods + + ### final\_index\_layout + + + 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 + + + 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 + + + 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 + + + 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 + + + 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/1.0/qiskit.transpiler.passes.ALAPSchedule.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ALAPSchedule.mdx new file mode 100644 index 00000000000..e69e0cb6305 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ALAPSchedule.mdx @@ -0,0 +1,118 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.ALAPScheduleAnalysis.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ALAPScheduleAnalysis.mdx new file mode 100644 index 00000000000..8f1dfa18633 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ALAPScheduleAnalysis.mdx @@ -0,0 +1,121 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.ASAPSchedule.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ASAPSchedule.mdx new file mode 100644 index 00000000000..d4b8ef8d5b0 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ASAPSchedule.mdx @@ -0,0 +1,122 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.ASAPScheduleAnalysis.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ASAPScheduleAnalysis.mdx new file mode 100644 index 00000000000..fa8a1988327 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ASAPScheduleAnalysis.mdx @@ -0,0 +1,121 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.AlignMeasures.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.AlignMeasures.mdx new file mode 100644 index 00000000000..6e6190ed190 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.AlignMeasures.mdx @@ -0,0 +1,155 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.ApplyLayout.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ApplyLayout.mdx new file mode 100644 index 00000000000..bb91247db8a --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ApplyLayout.mdx @@ -0,0 +1,111 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.mdx new file mode 100644 index 00000000000..511240b80e5 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.mdx @@ -0,0 +1,93 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the BarrierBeforeFinalMeasurements pass on dag. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.BasicSwap.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.BasicSwap.mdx new file mode 100644 index 00000000000..343b79a4f7d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.BasicSwap.mdx @@ -0,0 +1,117 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.BasisTranslator.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.BasisTranslator.mdx new file mode 100644 index 00000000000..9e83cb65946 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.BasisTranslator.mdx @@ -0,0 +1,162 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.CSPLayout.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CSPLayout.mdx new file mode 100644 index 00000000000..51f0391a82b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CSPLayout.mdx @@ -0,0 +1,108 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + run the layout method + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.CXCancellation.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CXCancellation.mdx new file mode 100644 index 00000000000..60d127945d6 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CXCancellation.mdx @@ -0,0 +1,103 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.CheckGateDirection.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CheckGateDirection.mdx new file mode 100644 index 00000000000..6cf9396f287 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CheckGateDirection.mdx @@ -0,0 +1,104 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.CheckMap.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CheckMap.mdx new file mode 100644 index 00000000000..ebf2d74f8a9 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CheckMap.mdx @@ -0,0 +1,106 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.Collect1qRuns.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Collect1qRuns.mdx new file mode 100644 index 00000000000..65a1c218af3 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Collect1qRuns.mdx @@ -0,0 +1,95 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.Collect2qBlocks.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Collect2qBlocks.mdx new file mode 100644 index 00000000000..75f22fa43dc --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Collect2qBlocks.mdx @@ -0,0 +1,95 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.CollectCliffords.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CollectCliffords.mdx new file mode 100644 index 00000000000..b2554946253 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CollectCliffords.mdx @@ -0,0 +1,109 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.CollectLinearFunctions.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CollectLinearFunctions.mdx new file mode 100644 index 00000000000..0a4320cc660 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CollectLinearFunctions.mdx @@ -0,0 +1,109 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.CollectMultiQBlocks.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CollectMultiQBlocks.mdx new file mode 100644 index 00000000000..0efb01d4b23 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CollectMultiQBlocks.mdx @@ -0,0 +1,119 @@ +--- +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 + + + 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 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 + + + 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 + + + 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 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/1.0/qiskit.transpiler.passes.CommutationAnalysis.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CommutationAnalysis.mdx new file mode 100644 index 00000000000..2dd8fa3b0af --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CommutationAnalysis.mdx @@ -0,0 +1,95 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.CommutativeCancellation.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CommutativeCancellation.mdx new file mode 100644 index 00000000000..5902cc4c4ea --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CommutativeCancellation.mdx @@ -0,0 +1,120 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.CommutativeInverseCancellation.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CommutativeInverseCancellation.mdx new file mode 100644 index 00000000000..cea8f2d4ca7 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CommutativeInverseCancellation.mdx @@ -0,0 +1,108 @@ +--- +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 + + + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + + Cancel pairs of inverse gates exploiting commutation relations. + + **Parameters** + + * **matrix\_based** – If `True`, uses matrix representations to check whether two operations are inverse of each other. This makes the checks more powerful, and, in addition, allows canceling pairs of operations that are inverse up to a phase, while updating the global phase of the circuit accordingly. Generally this leads to more reductions at the expense of increased runtime. + * **max\_qubits** – Limits the number of qubits in matrix-based commutativity and inverse checks. + + ## 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.Commuting2qGateRouter.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Commuting2qGateRouter.mdx new file mode 100644 index 00000000000..b8234b267ac --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Commuting2qGateRouter.mdx @@ -0,0 +1,194 @@ +--- +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 + + + 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.circuit.library import PauliEvolutionGate + from qiskit.quantum_info import SparsePauliOp + 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 = SparsePauliOp.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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 + + + 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 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/1.0/qiskit.transpiler.passes.ConsolidateBlocks.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ConsolidateBlocks.mdx new file mode 100644 index 00000000000..b63134c63f5 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ConsolidateBlocks.mdx @@ -0,0 +1,111 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the ConsolidateBlocks pass on dag. + + Iterate over each block and replace it with an equivalent Unitary on the same wires. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.ConstrainedReschedule.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ConstrainedReschedule.mdx new file mode 100644 index 00000000000..ba330d55f73 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ConstrainedReschedule.mdx @@ -0,0 +1,165 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.ContainsInstruction.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ContainsInstruction.mdx new file mode 100644 index 00000000000..fc9ef297289 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ContainsInstruction.mdx @@ -0,0 +1,100 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the ContainsInstruction pass on dag. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.ConvertConditionsToIfOps.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ConvertConditionsToIfOps.mdx new file mode 100644 index 00000000000..c6bda97b6f5 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ConvertConditionsToIfOps.mdx @@ -0,0 +1,101 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.CountOps.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CountOps.mdx new file mode 100644 index 00000000000..70920f1f5c8 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CountOps.mdx @@ -0,0 +1,93 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the CountOps pass on dag. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.CountOpsLongestPath.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CountOpsLongestPath.mdx new file mode 100644 index 00000000000..39292c12f35 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.CountOpsLongestPath.mdx @@ -0,0 +1,93 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the CountOpsLongestPath pass on dag. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.DAGFixedPoint.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.DAGFixedPoint.mdx new file mode 100644 index 00000000000..ad27701002e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.DAGFixedPoint.mdx @@ -0,0 +1,93 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the DAGFixedPoint pass on dag. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.DAGLongestPath.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.DAGLongestPath.mdx new file mode 100644 index 00000000000..74348235480 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.DAGLongestPath.mdx @@ -0,0 +1,91 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the DAGLongestPath pass on dag. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.Decompose.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Decompose.mdx new file mode 100644 index 00000000000..b9e5697c001 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Decompose.mdx @@ -0,0 +1,109 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.DenseLayout.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.DenseLayout.mdx new file mode 100644 index 00000000000..3d8eb7742dd --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.DenseLayout.mdx @@ -0,0 +1,115 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.Depth.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Depth.mdx new file mode 100644 index 00000000000..c514736f0cc --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Depth.mdx @@ -0,0 +1,95 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the Depth pass on dag. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.DynamicalDecoupling.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.DynamicalDecoupling.mdx new file mode 100644 index 00000000000..7950d987972 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.DynamicalDecoupling.mdx @@ -0,0 +1,192 @@ +--- +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 + + + 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/1.0/qiskit-transpiler-passes-DynamicalDecoupling-1_00.png) + + ![../\_images/qiskit-transpiler-passes-DynamicalDecoupling-1\_01.png](/images/api/qiskit/1.0/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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.EchoRZXWeylDecomposition.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.EchoRZXWeylDecomposition.mdx new file mode 100644 index 00000000000..e1198855e45 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.EchoRZXWeylDecomposition.mdx @@ -0,0 +1,118 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.EnlargeWithAncilla.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.EnlargeWithAncilla.mdx new file mode 100644 index 00000000000..9c543a3ef81 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.EnlargeWithAncilla.mdx @@ -0,0 +1,109 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.FilterOpNodes.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.FilterOpNodes.mdx new file mode 100644 index 00000000000..dfbdfc09089 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.FilterOpNodes.mdx @@ -0,0 +1,122 @@ +--- +title: FilterOpNodes +description: API reference for qiskit.transpiler.passes.FilterOpNodes +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.FilterOpNodes +--- + +# FilterOpNodes + + + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + + Remove all operations that match a filter function + + This transformation pass is used to remove any operations that matches a the provided filter function. + + **Parameters** + + **predicate** – A given callable that will be passed the [`DAGOpNode`](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode") for each node in the [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit"). If the callable returns `True` the [`DAGOpNode`](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode") is retained in the circuit and if it returns `False` it is removed from the circuit. + + **Example** + + Filter out operations that are labelled `"foo"` + + ```python + from qiskit import QuantumCircuit + from qiskit.transpiler.passes import FilterOpNodes + + circuit = QuantumCircuit(1) + circuit.x(0, label='foo') + circuit.barrier() + circuit.h(0) + + circuit = FilterOpNodes( + lambda node: getattr(node.op, "label") != "foo" + )(circuit) + circuit.draw('mpl') + ``` + + ![../\_images/qiskit-transpiler-passes-FilterOpNodes-1.png](/images/api/qiskit/1.0/qiskit-transpiler-passes-FilterOpNodes-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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the RemoveBarriers pass on dag. + + **Return type** + + [*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.FixedPoint.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.FixedPoint.mdx new file mode 100644 index 00000000000..0bb11d9f0f1 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.FixedPoint.mdx @@ -0,0 +1,99 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the FixedPoint pass on dag. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.FullAncillaAllocation.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.FullAncillaAllocation.mdx new file mode 100644 index 00000000000..98fcb0cb9af --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.FullAncillaAllocation.mdx @@ -0,0 +1,129 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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 + + + Checks if all the qregs in `layout_qregs` already exist in `dag_qregs`. Otherwise, raise. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.GateDirection.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.GateDirection.mdx new file mode 100644 index 00000000000..5fd8b0662ce --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.GateDirection.mdx @@ -0,0 +1,143 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.GatesInBasis.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.GatesInBasis.mdx new file mode 100644 index 00000000000..460797ad597 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.GatesInBasis.mdx @@ -0,0 +1,98 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the GatesInBasis pass on dag. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.HLSConfig.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.HLSConfig.mdx new file mode 100644 index 00000000000..45b076d649d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.HLSConfig.mdx @@ -0,0 +1,63 @@ +--- +title: HLSConfig +description: API reference for qiskit.transpiler.passes.HLSConfig +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.HLSConfig +--- + +# HLSConfig + + + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + + The high-level-synthesis config allows to specify a list of “methods” used by [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis") transformation pass to synthesize different types of higher-level objects. + + A higher-level object is an object of type [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") (e.g., [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") or [`LinearFunction`](qiskit.circuit.library.LinearFunction "qiskit.circuit.library.LinearFunction")). Each object is referred to by its [`name`](qiskit.circuit.Operation#name "qiskit.circuit.Operation.name") field (e.g., `"clifford"` for [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") objects), and the applicable synthesis methods are tied to this name. + + In the config, each method is specified in one of several ways: + + 1. a tuple consisting of the name of a known synthesis plugin and a dictionary providing additional arguments for the algorithm. + 2. a tuple consisting of an instance of [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") and additional arguments for the algorithm. + 3. a single string of a known synthesis plugin + 4. a single instance of [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin"). + + The following example illustrates different ways how a config file can be created: + + ```python + from qiskit.transpiler.passes.synthesis.high_level_synthesis import HLSConfig + from qiskit.transpiler.passes.synthesis.high_level_synthesis import ACGSynthesisPermutation + + # All the ways to specify hls_config are equivalent + hls_config = HLSConfig(permutation=[("acg", {})]) + hls_config = HLSConfig(permutation=["acg"]) + hls_config = HLSConfig(permutation=[(ACGSynthesisPermutation(), {})]) + hls_config = HLSConfig(permutation=[ACGSynthesisPermutation()]) + ``` + + The names of the synthesis plugins should be declared in `entry-points` table for `qiskit.synthesis` in `pyproject.toml`, in the form \.\. + + The standard higher-level-objects are recommended to have a synthesis method called “default”, which would be called automatically when synthesizing these objects, without having to explicitly set these methods in the config. + + To avoid synthesizing a given higher-level-object, one can give it an empty list of methods. + + For an explicit example of using such config files, refer to the documentation for [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis"). + + For an overview of the complete process of using high-level synthesis, see [High-level Synthesis Plugins](transpiler_synthesis_plugins#using-high-level-synthesis-plugins). + + Creates a high-level-synthesis config. + + **Parameters** + + * **use\_default\_on\_unspecified** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, every higher-level-object without an explicitly specified list of methods will be synthesized using the “default” algorithm if it exists. + * **kwargs** – a dictionary mapping higher-level-objects to lists of synthesis methods. + + ## Methods + + ### set\_methods + + + Sets the list of synthesis methods for a given higher-level-object. This overwrites the lists of methods if also set previously. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.HighLevelSynthesis.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.HighLevelSynthesis.mdx new file mode 100644 index 00000000000..8f9106b6d84 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.HighLevelSynthesis.mdx @@ -0,0 +1,142 @@ +--- +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 + + + 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`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.HoareOptimizer.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.HoareOptimizer.mdx new file mode 100644 index 00000000000..6f272bceac7 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.HoareOptimizer.mdx @@ -0,0 +1,109 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + **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 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/1.0/qiskit.transpiler.passes.InstructionDurationCheck.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.InstructionDurationCheck.mdx new file mode 100644 index 00000000000..7d4aeb6d379 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.InstructionDurationCheck.mdx @@ -0,0 +1,108 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run duration validation passes. + + **Parameters** + + **dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – DAG circuit to check instruction durations. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.InverseCancellation.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.InverseCancellation.mdx new file mode 100644 index 00000000000..ae58fbb7f5b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.InverseCancellation.mdx @@ -0,0 +1,113 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.Layout2qDistance.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Layout2qDistance.mdx new file mode 100644 index 00000000000..ea937d76a85 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Layout2qDistance.mdx @@ -0,0 +1,100 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the Layout2qDistance pass on dag. :param dag: DAG to evaluate. :type dag: DAGCircuit + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.LinearFunctionsToPermutations.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.LinearFunctionsToPermutations.mdx new file mode 100644 index 00000000000..24cf9ecf8c2 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.LinearFunctionsToPermutations.mdx @@ -0,0 +1,99 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.LookaheadSwap.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.LookaheadSwap.mdx new file mode 100644 index 00000000000..7cc5df1e7b6 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.LookaheadSwap.mdx @@ -0,0 +1,135 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.MergeAdjacentBarriers.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.MergeAdjacentBarriers.mdx new file mode 100644 index 00000000000..ce2aa8f5ba4 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.MergeAdjacentBarriers.mdx @@ -0,0 +1,128 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the MergeAdjacentBarriers pass on dag. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.MinimumPoint.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.MinimumPoint.mdx new file mode 100644 index 00000000000..a265d5dd8d9 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.MinimumPoint.mdx @@ -0,0 +1,111 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the MinimumPoint pass on dag. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.NormalizeRXAngle.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.NormalizeRXAngle.mdx new file mode 100644 index 00000000000..ecaa7f7d123 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.NormalizeRXAngle.mdx @@ -0,0 +1,144 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### quantize\_angles + + + Quantize the RX rotation angles by assigning the same value for the angles that differ within a resolution provided by the user. + + **Parameters** + + * **qubit** ([*qiskit.circuit.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 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 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/1.0/qiskit.transpiler.passes.NumTensorFactors.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.NumTensorFactors.mdx new file mode 100644 index 00000000000..d1116661d30 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.NumTensorFactors.mdx @@ -0,0 +1,93 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the NumTensorFactors pass on dag. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.Optimize1qGates.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Optimize1qGates.mdx new file mode 100644 index 00000000000..a6d4101191d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Optimize1qGates.mdx @@ -0,0 +1,144 @@ +--- +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 + + + 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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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 + + + 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/1.0/qiskit.transpiler.passes.Optimize1qGatesDecomposition.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Optimize1qGatesDecomposition.mdx new file mode 100644 index 00000000000..fe41c71dcfc --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Optimize1qGatesDecomposition.mdx @@ -0,0 +1,119 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.mdx new file mode 100644 index 00000000000..dd3510b26d5 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.mdx @@ -0,0 +1,113 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + **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 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/1.0/qiskit.transpiler.passes.OptimizeAnnotated.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.OptimizeAnnotated.mdx new file mode 100644 index 00000000000..e29d4dabcf5 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.OptimizeAnnotated.mdx @@ -0,0 +1,118 @@ +--- +title: OptimizeAnnotated +description: API reference for qiskit.transpiler.passes.OptimizeAnnotated +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.OptimizeAnnotated +--- + +# OptimizeAnnotated + + + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + + Optimization pass on circuits with annotated operations. + + Implemented optimizations: + + * For each annotated operation, converting the list of its modifiers to a canonical form. For example, consecutively applying `inverse()`, `control(2)` and `inverse()` is equivalent to applying `control(2)`. + * Removing annotations when possible. For example, `AnnotatedOperation(SwapGate(), [InverseModifier(), InverseModifier()])` is equivalent to `SwapGate()`. + * Recursively combining annotations. For example, if `g1 = AnnotatedOperation(SwapGate(), InverseModifier())` and `g2 = AnnotatedOperation(g1, ControlModifier(2))`, then `g2` can be replaced with `AnnotatedOperation(SwapGate(), [InverseModifier(), ControlModifier(2)])`. + + OptimizeAnnotated initializer. + + **Parameters** + + * **target** – Optional, the backend target to use for this pass. + * **equivalence\_library** – The equivalence library used (instructions in this library will not be optimized by this pass). + * **basis\_gates** – Optional, target basis names to unroll to, e.g. \[‘u3’, ‘cx’] (instructions in this list will not be optimized by this pass). Ignored if `target` is also specified. + * **recurse** – By default, when either `target` or `basis_gates` is specified, the pass recursively descends into gate definitions (and the recursion is not applied when neither is specified since such objects do not need to be synthesized). Setting this value to `False` precludes the recursion in every case. + + ## 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the OptimizeAnnotated pass on dag. + + **Parameters** + + **dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – input dag. + + **Returns** + + Output dag with higher-level operations optimized. + + **Raises** + + [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – when something goes wrong. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.OptimizeCliffords.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.OptimizeCliffords.mdx new file mode 100644 index 00000000000..88a3e5c68f2 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.OptimizeCliffords.mdx @@ -0,0 +1,103 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.PadDelay.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.PadDelay.mdx new file mode 100644 index 00000000000..12546defb2b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.PadDelay.mdx @@ -0,0 +1,139 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.PadDynamicalDecoupling.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.PadDynamicalDecoupling.mdx new file mode 100644 index 00000000000..d0a1f218a78 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.PadDynamicalDecoupling.mdx @@ -0,0 +1,197 @@ +--- +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 + + + 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/1.0/qiskit-transpiler-passes-PadDynamicalDecoupling-1_00.png) + + ![../\_images/qiskit-transpiler-passes-PadDynamicalDecoupling-1\_01.png](/images/api/qiskit/1.0/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. Target takes precedence over other arguments when they can be inferred from target. Therefore specifying target as well as other arguments like `durations` or `pulse_alignment` will cause those other arguments to 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.PulseGates.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.PulseGates.mdx new file mode 100644 index 00000000000..a1b3d65957c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.PulseGates.mdx @@ -0,0 +1,164 @@ +--- +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 + + + 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 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 + + + 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 + + + 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 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/1.0/qiskit.transpiler.passes.RXCalibrationBuilder.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.RXCalibrationBuilder.mdx new file mode 100644 index 00000000000..591dd5407b3 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.RXCalibrationBuilder.mdx @@ -0,0 +1,173 @@ +--- +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 + + + 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 GenericBackendV2 + 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 = GenericBackendV2(5) + 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 = GenericBackendV2(5) + 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 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 + + + 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 + + + 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 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/1.0/qiskit.transpiler.passes.RZXCalibrationBuilder.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.RZXCalibrationBuilder.mdx new file mode 100644 index 00000000000..910e676d8f1 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.RZXCalibrationBuilder.mdx @@ -0,0 +1,183 @@ +--- +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 + + + 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 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 + + + 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### rescale\_cr\_inst + + + 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 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 + + + 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 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/1.0/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.mdx new file mode 100644 index 00000000000..6c55a815862 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.mdx @@ -0,0 +1,185 @@ +--- +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 + + + 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 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 + + + 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### rescale\_cr\_inst + + + 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 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 + + + 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 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/1.0/qiskit.transpiler.passes.RemoveBarriers.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.RemoveBarriers.mdx new file mode 100644 index 00000000000..a8060a32f62 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.RemoveBarriers.mdx @@ -0,0 +1,114 @@ +--- +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 + + + 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/1.0/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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the RemoveBarriers pass on dag. + + **Return type** + + [*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.mdx new file mode 100644 index 00000000000..cf7fc4286c8 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.mdx @@ -0,0 +1,105 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.RemoveFinalMeasurements.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.RemoveFinalMeasurements.mdx new file mode 100644 index 00000000000..907b14dabf0 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.RemoveFinalMeasurements.mdx @@ -0,0 +1,107 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.RemoveResetInZeroState.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.RemoveResetInZeroState.mdx new file mode 100644 index 00000000000..6e8bf935a49 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.RemoveResetInZeroState.mdx @@ -0,0 +1,103 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.ResetAfterMeasureSimplification.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ResetAfterMeasureSimplification.mdx new file mode 100644 index 00000000000..a606e7265ab --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ResetAfterMeasureSimplification.mdx @@ -0,0 +1,93 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the pass on a dag. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.SabreLayout.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.SabreLayout.mdx new file mode 100644 index 00000000000..51bc94baa28 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.SabreLayout.mdx @@ -0,0 +1,203 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.SabrePreLayout.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.SabrePreLayout.mdx new file mode 100644 index 00000000000..aa08ccb5dcd --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.SabrePreLayout.mdx @@ -0,0 +1,161 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.SabreSwap.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.SabreSwap.mdx new file mode 100644 index 00000000000..ac65f99a073 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.SabreSwap.mdx @@ -0,0 +1,168 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.SetIOLatency.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.SetIOLatency.mdx new file mode 100644 index 00000000000..9d68f6093a1 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.SetIOLatency.mdx @@ -0,0 +1,106 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Add IO latency information. + + **Parameters** + + **dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – Input DAG circuit. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.SetLayout.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.SetLayout.mdx new file mode 100644 index 00000000000..57ec405f824 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.SetLayout.mdx @@ -0,0 +1,116 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.Size.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Size.mdx new file mode 100644 index 00000000000..b79673ed7ef --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Size.mdx @@ -0,0 +1,97 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the Size pass on dag. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.SolovayKitaev.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.SolovayKitaev.mdx new file mode 100644 index 00000000000..3338fd87067 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.SolovayKitaev.mdx @@ -0,0 +1,196 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.StochasticSwap.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.StochasticSwap.mdx new file mode 100644 index 00000000000..8e98bbb0eed --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.StochasticSwap.mdx @@ -0,0 +1,129 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.TemplateOptimization.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.TemplateOptimization.mdx new file mode 100644 index 00000000000..e2e2637dfb8 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.TemplateOptimization.mdx @@ -0,0 +1,112 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + **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 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/1.0/qiskit.transpiler.passes.TimeUnitConversion.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.TimeUnitConversion.mdx new file mode 100644 index 00000000000..04d0a90fceb --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.TimeUnitConversion.mdx @@ -0,0 +1,122 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.TranslateParameterizedGates.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.TranslateParameterizedGates.mdx new file mode 100644 index 00000000000..234d5354057 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.TranslateParameterizedGates.mdx @@ -0,0 +1,164 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.TrivialLayout.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.TrivialLayout.mdx new file mode 100644 index 00000000000..7686c8c4b0b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.TrivialLayout.mdx @@ -0,0 +1,115 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.UnitarySynthesis.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.UnitarySynthesis.mdx new file mode 100644 index 00000000000..16bf02d5ea4 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.UnitarySynthesis.mdx @@ -0,0 +1,125 @@ +--- +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 + + + 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`. + + **Raises** + + [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if `method` was specified but 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") + + ## 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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. + + **Return type** + + [*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.Unroll3qOrMore.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Unroll3qOrMore.mdx new file mode 100644 index 00000000000..3bb2ec28311 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Unroll3qOrMore.mdx @@ -0,0 +1,114 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.UnrollCustomDefinitions.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.UnrollCustomDefinitions.mdx new file mode 100644 index 00000000000..d7a9c76b4a3 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.UnrollCustomDefinitions.mdx @@ -0,0 +1,126 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.UnrollForLoops.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.UnrollForLoops.mdx new file mode 100644 index 00000000000..478fa2ca07a --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.UnrollForLoops.mdx @@ -0,0 +1,113 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.VF2Layout.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.VF2Layout.mdx new file mode 100644 index 00000000000..6a5eeedcaa1 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.VF2Layout.mdx @@ -0,0 +1,127 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + run the layout method + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.VF2PostLayout.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.VF2PostLayout.mdx new file mode 100644 index 00000000000..8eb9eada142 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.VF2PostLayout.mdx @@ -0,0 +1,130 @@ +--- +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 + + + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + + A pass for improving an existing 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 or no better 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. + > * `"no better solution found"`: If the initial layout of the circuit is the best solution. + > * `"nonexistent solution"`: If no solution was found. + > * `">2q gates in basis"`: If VF2PostLayout can’t work with the basis of the circuit. + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + run the layout method + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.ValidatePulseGates.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ValidatePulseGates.mdx new file mode 100644 index 00000000000..802a45f4590 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.ValidatePulseGates.mdx @@ -0,0 +1,122 @@ +--- +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 + + + 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](/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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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 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/1.0/qiskit.transpiler.passes.Width.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Width.mdx new file mode 100644 index 00000000000..2cca67ecf72 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.Width.mdx @@ -0,0 +1,93 @@ +--- +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 + + + 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the Width pass on dag. + + + ### update\_status + + + 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/1.0/qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin.mdx new file mode 100644 index 00000000000..631e5e1bf1d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin.mdx @@ -0,0 +1,177 @@ +--- +title: AQCSynthesisPlugin +description: API reference for qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin +--- + +# AQCSynthesisPlugin + + + 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 (`Minimizer`)** + + An implementation of the `Minimizer` protocol 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 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/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation.mdx new file mode 100644 index 00000000000..a45ffc142c7 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation.mdx @@ -0,0 +1,26 @@ +--- +title: ACGSynthesisPermutation +description: API reference for qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation +--- + +# ACGSynthesisPermutation + + + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") + + The permutation synthesis plugin based on the Alon, Chung, Graham method. + + This plugin name is :`permutation.acg` which can be used as the key on an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.HLSConfig") object to use this method with [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis"). + + ## Methods + + ### run + + + Run synthesis for the given Permutation. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford.mdx new file mode 100644 index 00000000000..e02ff9ca2b2 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford.mdx @@ -0,0 +1,26 @@ +--- +title: AGSynthesisClifford +description: API reference for qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford +--- + +# AGSynthesisClifford + + + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") + + Clifford synthesis plugin based on the Aaronson-Gottesman method. + + This plugin name is :`clifford.ag` which can be used as the key on an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.HLSConfig") object to use this method with [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis"). + + ## Methods + + ### run + + + Run synthesis for the given Clifford. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford.mdx new file mode 100644 index 00000000000..aa8c39dfcae --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford.mdx @@ -0,0 +1,28 @@ +--- +title: BMSynthesisClifford +description: API reference for qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford +--- + +# BMSynthesisClifford + + + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") + + Clifford synthesis plugin based on the Bravyi-Maslov method. + + The method only works on Cliffords with at most 3 qubits, for which it constructs the optimal CX cost decomposition. + + This plugin name is :`clifford.bm` which can be used as the key on an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.HLSConfig") object to use this method with [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis"). + + ## Methods + + ### run + + + Run synthesis for the given Clifford. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation.mdx new file mode 100644 index 00000000000..bdf0d5da614 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation.mdx @@ -0,0 +1,26 @@ +--- +title: BasicSynthesisPermutation +description: API reference for qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation +--- + +# BasicSynthesisPermutation + + + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") + + The permutation synthesis plugin based on sorting. + + This plugin name is :`permutation.basic` which can be used as the key on an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.HLSConfig") object to use this method with [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis"). + + ## Methods + + ### run + + + Run synthesis for the given Permutation. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford.mdx new file mode 100644 index 00000000000..503b4e865aa --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford.mdx @@ -0,0 +1,28 @@ +--- +title: DefaultSynthesisClifford +description: API reference for qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford +--- + +# DefaultSynthesisClifford + + + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") + + The default clifford synthesis plugin. + + For N \<= 3 qubits this is the optimal CX cost decomposition by Bravyi, Maslov. For N > 3 qubits this is done using the general non-optimal greedy compilation routine from reference by Bravyi, Hu, Maslov, Shaydulin. + + This plugin name is :`clifford.default` which can be used as the key on an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.HLSConfig") object to use this method with [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis"). + + ## Methods + + ### run + + + Run synthesis for the given Clifford. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction.mdx new file mode 100644 index 00000000000..4b7b29aa307 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction.mdx @@ -0,0 +1,26 @@ +--- +title: DefaultSynthesisLinearFunction +description: API reference for qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction +--- + +# DefaultSynthesisLinearFunction + + + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") + + The default linear function synthesis plugin. + + This plugin name is :`linear_function.default` which can be used as the key on an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.HLSConfig") object to use this method with [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis"). + + ## Methods + + ### run + + + Run synthesis for the given LinearFunction. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford.mdx new file mode 100644 index 00000000000..091d0432b03 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford.mdx @@ -0,0 +1,26 @@ +--- +title: GreedySynthesisClifford +description: API reference for qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford +--- + +# GreedySynthesisClifford + + + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") + + Clifford synthesis plugin based on the greedy synthesis Bravyi-Hu-Maslov-Shaydulin method. + + This plugin name is :`clifford.greedy` which can be used as the key on an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.HLSConfig") object to use this method with [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis"). + + ## Methods + + ### run + + + Run synthesis for the given Clifford. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction.mdx new file mode 100644 index 00000000000..8bb9ab53c64 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction.mdx @@ -0,0 +1,26 @@ +--- +title: KMSSynthesisLinearFunction +description: API reference for qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction +--- + +# KMSSynthesisLinearFunction + + + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") + + Linear function synthesis plugin based on the Kutin-Moulton-Smithline method. + + This plugin name is :`linear_function.kms` which can be used as the key on an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.HLSConfig") object to use this method with [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis"). + + ## Methods + + ### run + + + Run synthesis for the given LinearFunction. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation.mdx new file mode 100644 index 00000000000..e0c815c0c58 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation.mdx @@ -0,0 +1,26 @@ +--- +title: KMSSynthesisPermutation +description: API reference for qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation +--- + +# KMSSynthesisPermutation + + + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") + + The permutation synthesis plugin based on the Kutin, Moulton, Smithline method. + + This plugin name is :`permutation.kms` which can be used as the key on an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.HLSConfig") object to use this method with [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis"). + + ## Methods + + ### run + + + Run synthesis for the given Permutation. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford.mdx new file mode 100644 index 00000000000..98668534620 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford.mdx @@ -0,0 +1,26 @@ +--- +title: LayerLnnSynthesisClifford +description: API reference for qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford +--- + +# LayerLnnSynthesisClifford + + + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") + + Clifford synthesis plugin based on the Bravyi-Maslov method to synthesize Cliffords into layers, with each layer synthesized adhering to LNN connectivity. + + This plugin name is :`clifford.lnn` which can be used as the key on an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.HLSConfig") object to use this method with [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis"). + + ## Methods + + ### run + + + Run synthesis for the given Clifford. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford.mdx new file mode 100644 index 00000000000..22530da0228 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford.mdx @@ -0,0 +1,26 @@ +--- +title: LayerSynthesisClifford +description: API reference for qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford +--- + +# LayerSynthesisClifford + + + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") + + Clifford synthesis plugin based on the Bravyi-Maslov method to synthesize Cliffords into layers. + + This plugin name is :`clifford.layers` which can be used as the key on an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.HLSConfig") object to use this method with [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis"). + + ## Methods + + ### run + + + Run synthesis for the given Clifford. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction.mdx new file mode 100644 index 00000000000..44671845c1f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction.mdx @@ -0,0 +1,26 @@ +--- +title: PMHSynthesisLinearFunction +description: API reference for qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction +--- + +# PMHSynthesisLinearFunction + + + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") + + Linear function synthesis plugin based on the Patel-Markov-Hayes method. + + This plugin name is :`linear_function.pmh` which can be used as the key on an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.HLSConfig") object to use this method with [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis"). + + ## Methods + + ### run + + + Run synthesis for the given LinearFunction. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation.mdx new file mode 100644 index 00000000000..65a1e1002fa --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation.mdx @@ -0,0 +1,40 @@ +--- +title: TokenSwapperSynthesisPermutation +description: API reference for qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation +--- + +# TokenSwapperSynthesisPermutation + + + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") + + The permutation synthesis plugin based on the token swapper algorithm. + + This plugin name is :`permutation.token_swapper` which can be used as the key on an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.HLSConfig") object to use this method with [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis"). + + In more detail, this plugin is used to synthesize objects of type PermutationGate. When synthesis succeeds, the plugin outputs a quantum circuit consisting only of swap gates. When synthesis does not succeed, the plugin outputs None. + + If either coupling\_map or qubits is None, then the synthesized circuit is not required to adhere to connectivity constraints, as is the case when the synthesis is done before layout/routing. + + On the other hand, if both coupling\_map and qubits are specified, the synthesized circuit is supposed to adhere to connectivity constraints. At the moment, the plugin only creates swap gates between qubits in qubits, i.e. it does not use any other qubits in the coupling map (if such synthesis is not possible, the plugin outputs None). + + The plugin supports the following plugin-specific options: + + * trials: The number of trials for the token swapper to perform the mapping. The circuit with the smallest number of SWAPs is returned. + * seed: The argument to the token swapper specifying the seed for random trials. + * parallel\_threshold: The argument to the token swapper specifying the number of nodes in the graph beyond which the algorithm will use parallel processing. + + For more details on the token swapper algorithm, see to the paper: [arXiv:1902.09102](https://arxiv.org/abs/1902.09102). + + ## Methods + + ### run + + + Run synthesis for the given Permutation. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.mdx new file mode 100644 index 00000000000..43a52a7a3d6 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.mdx @@ -0,0 +1,44 @@ +--- +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 + + + 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 + + + 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/1.0/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.mdx new file mode 100644 index 00000000000..a9d226762fc --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.mdx @@ -0,0 +1,30 @@ +--- +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 + + + 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 + + + Returns the plugin for `op_name` and `method_name`. + + + ### method\_names + + + Returns plugin methods for op\_name. + + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.mdx new file mode 100644 index 00000000000..4d6a8081656 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.mdx @@ -0,0 +1,196 @@ +--- +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 + + + 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 + + + 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/1.0/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.mdx new file mode 100644 index 00000000000..f9248907db3 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.mdx @@ -0,0 +1,18 @@ +--- +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 + + + 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/1.0/qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names.mdx new file mode 100644 index 00000000000..b58b853d0e0 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names.mdx @@ -0,0 +1,28 @@ +--- +title: high_level_synthesis_plugin_names +description: API reference for qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names +--- + + + +# qiskit.transpiler.passes.synthesis.plugin.high\_level\_synthesis\_plugin\_names + + + Return a list of plugin names installed for a given high level object name + + **Parameters** + + **op\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The operation name to find the installed plugins for. For example, if you provide `"clifford"` as the input it will find all the installed clifford synthesis plugins that can synthesize [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") objects. The name refers to the [`Operation.name`](qiskit.circuit.Operation#name "qiskit.circuit.Operation.name") attribute of the relevant objects. + + **Returns** + + A list of installed plugin names for the specified high level operation + + **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)")] + + diff --git a/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.mdx new file mode 100644 index 00000000000..582f866f69d --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.mdx @@ -0,0 +1,24 @@ +--- +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 + + + 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/1.0/qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis.mdx new file mode 100644 index 00000000000..b1ada293692 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis.mdx @@ -0,0 +1,169 @@ +--- +title: SolovayKitaevSynthesis +description: API reference for qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis +--- + +# SolovayKitaevSynthesis + + + 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 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/1.0/qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis.mdx new file mode 100644 index 00000000000..2064046c12e --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis.mdx @@ -0,0 +1,87 @@ +--- +title: DefaultUnitarySynthesis +description: API reference for qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis +--- + +# DefaultUnitarySynthesis + + + Bases: [`UnitarySynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin") + + The default unitary synthesis plugin. + + ## Attributes + + ### max\_qubits + + + + ### min\_qubits + + + + ### supported\_bases + + + + ### supports\_basis\_gates + + + + ### supports\_coupling\_map + + + + ### supports\_gate\_errors + + + + ### supports\_gate\_errors\_by\_qubit + + + + ### supports\_gate\_lengths + + + + ### supports\_gate\_lengths\_by\_qubit + + + + ### supports\_natural\_direction + + + + ### supports\_pulse\_optimize + + + + ### supports\_target + + + + ## Methods + + ### run + + + 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/1.0/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.mdx new file mode 100644 index 00000000000..b21c2efe90f --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.mdx @@ -0,0 +1,35 @@ +--- +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 + + + 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 + + + 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/1.0/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.mdx b/docs/api/qiskit/1.0/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.mdx new file mode 100644 index 00000000000..b60c7c91c08 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.mdx @@ -0,0 +1,28 @@ +--- +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 + + + 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 a stage + + **Return type** + + [*PassManager*](qiskit.transpiler.PassManager "qiskit.transpiler.passmanager.PassManager") + + + diff --git a/docs/api/qiskit/1.0/qiskit.visualization.array_to_latex.mdx b/docs/api/qiskit/1.0/qiskit.visualization.array_to_latex.mdx new file mode 100644 index 00000000000..94603dc1d82 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.array_to_latex.mdx @@ -0,0 +1,49 @@ +--- +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 + + + 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/1.0/qiskit.visualization.circuit_drawer.mdx b/docs/api/qiskit/1.0/qiskit.visualization.circuit_drawer.mdx new file mode 100644 index 00000000000..0af992a0dd8 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.circuit_drawer.mdx @@ -0,0 +1,121 @@ +--- +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 + + + 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** + + * **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The circuit to visualize. + + * **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – 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)") *| None*) – File path to save image to. Defaults to `None` (result not saved in a file). + + * **style** ([*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)") *| None*) – + + Style name, file name of style JSON file, or a dictionary specifying the style. + + * **The supported style names are `"iqp"` (default), `"iqp-dark"`, `"clifford"`,** + + `"textbook"` and `"bw"`. + + * **If given a JSON file, e.g. `my_style.json` or `my_style` (the `.json`** + + extension may be omitted), this function attempts to load the style dictionary from that location. Note, that the JSON file must completely specify the visualization specifications. The file is searched for in `qiskit/visualization/circuit/styles`, the current working directory, and the location specified in `~/.qiskit/settings.conf`. + + * **If a dictionary, every entry overrides the default configuration. If the** + + `"name"` key is given, the default configuration is given by that style. For example, `{"name": "textbook", "subfontsize": 5}` loads the `"texbook"` style and sets the subfontsize (e.g. the gate angles) to `5`. + + * **If `None` the default style `"iqp"` is used or, if given, the default style** + + specified in `~/.qiskit/settings.conf`. + + * **output** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – 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)") *| None*) – 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** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – 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** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – `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)") *| None*) – 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** (*Any | None*) – Only used by the mpl backend. An optional `matplotlib.axes.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)")) – Adds $|0\rangle$ in the beginning of the qubit wires and $0$ to classical wires. Default is `False`. + + * **cregbundle** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If set to `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)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – 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)")) – 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` (if `output='text'`)** + + A drawing that can be printed as ascii art. + + * **`matplotlib.figure.Figure` (if `output='mpl'`)** + + A matplotlib figure object for the circuit diagram. + + * **`PIL.Image` (if `output='latex`’)** + + An in-memory representation of the image of the circuit diagram. + + * **`str` (if `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 + qc = QuantumCircuit(1, 1) + qc.h(0) + qc.measure(0, 0) + qc.draw(output='mpl', style={'backgroundcolor': '#EEEEEE'}) + ``` + + ![../\_images/qiskit-visualization-circuit\_drawer-1.png](/images/api/qiskit/1.0/qiskit-visualization-circuit_drawer-1.png) + + diff --git a/docs/api/qiskit/1.0/qiskit.visualization.dag_drawer.mdx b/docs/api/qiskit/1.0/qiskit.visualization.dag_drawer.mdx new file mode 100644 index 00000000000..dbdab7055bd --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.dag_drawer.mdx @@ -0,0 +1,60 @@ +--- +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 + + + 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)") 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/1.0/qiskit.visualization.pass_manager_drawer.mdx b/docs/api/qiskit/1.0/qiskit.visualization.pass_manager_drawer.mdx new file mode 100644 index 00000000000..26a916011e8 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.pass_manager_drawer.mdx @@ -0,0 +1,60 @@ +--- +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 + + + 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/1.0/qiskit.visualization.plot_bloch_multivector.mdx b/docs/api/qiskit/1.0/qiskit.visualization.plot_bloch_multivector.mdx new file mode 100644 index 00000000000..02f04ebabe2 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.plot_bloch_multivector.mdx @@ -0,0 +1,83 @@ +--- +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 + + + 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.4)") + + **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/1.0/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/1.0/qiskit-visualization-plot_bloch_multivector-2.png) + + diff --git a/docs/api/qiskit/1.0/qiskit.visualization.plot_bloch_vector.mdx b/docs/api/qiskit/1.0/qiskit.visualization.plot_bloch_vector.mdx new file mode 100644 index 00000000000..5c874fdb286 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.plot_bloch_vector.mdx @@ -0,0 +1,60 @@ +--- +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 + + + 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.4)")) – 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.4)") + + **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/1.0/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/1.0/qiskit-visualization-plot_bloch_vector-2.png) + + diff --git a/docs/api/qiskit/1.0/qiskit.visualization.plot_circuit_layout.mdx b/docs/api/qiskit/1.0/qiskit.visualization.plot_circuit_layout.mdx new file mode 100644 index 00000000000..6813b7191eb --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.plot_circuit_layout.mdx @@ -0,0 +1,56 @@ +--- +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 + + + 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 + from qiskit import QuantumCircuit, transpile + from qiskit.providers.fake_provider import GenericBackendV2 + from qiskit.visualization import plot_circuit_layout + + ghz = QuantumCircuit(3, 3) + ghz.h(0) + for idx in range(1,3): + ghz.cx(0,idx) + ghz.measure(range(3), range(3)) + + backend = GenericBackendV2(num_qubits=5) + 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/1.0/qiskit-visualization-plot_circuit_layout-1.png) + + diff --git a/docs/api/qiskit/1.0/qiskit.visualization.plot_coupling_map.mdx b/docs/api/qiskit/1.0/qiskit.visualization.plot_coupling_map.mdx new file mode 100644 index 00000000000..ae6280cebff --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.plot_coupling_map.mdx @@ -0,0 +1,60 @@ +--- +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 + + + 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/1.0/qiskit-visualization-plot_coupling_map-1.png) + + diff --git a/docs/api/qiskit/1.0/qiskit.visualization.plot_distribution.mdx b/docs/api/qiskit/1.0/qiskit.visualization.plot_distribution.mdx new file mode 100644 index 00000000000..a00104de803 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.plot_distribution.mdx @@ -0,0 +1,77 @@ +--- +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 + + + 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.4)")) – 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/1.0/qiskit-visualization-plot_distribution-1_00.png) + + ![../\_images/qiskit-visualization-plot\_distribution-1\_01.png](/images/api/qiskit/1.0/qiskit-visualization-plot_distribution-1_01.png) + + ![../\_images/qiskit-visualization-plot\_distribution-1\_02.png](/images/api/qiskit/1.0/qiskit-visualization-plot_distribution-1_02.png) + + diff --git a/docs/api/qiskit/1.0/qiskit.visualization.plot_error_map.mdx b/docs/api/qiskit/1.0/qiskit.visualization.plot_error_map.mdx new file mode 100644 index 00000000000..b314582fd81 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.plot_error_map.mdx @@ -0,0 +1,48 @@ +--- +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 + + + 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.visualization import plot_error_map + from qiskit.providers.fake_provider import GenericBackendV2 + + backend = GenericBackendV2(num_qubits=5) + plot_error_map(backend) + ``` + + ![../\_images/qiskit-visualization-plot\_error\_map-1.png](/images/api/qiskit/1.0/qiskit-visualization-plot_error_map-1.png) + + diff --git a/docs/api/qiskit/1.0/qiskit.visualization.plot_gate_map.mdx b/docs/api/qiskit/1.0/qiskit.visualization.plot_gate_map.mdx new file mode 100644 index 00000000000..db73f3a4c4a --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.plot_gate_map.mdx @@ -0,0 +1,59 @@ +--- +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 + + + 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.providers.fake_provider import GenericBackendV2 + from qiskit.visualization import plot_gate_map + + backend = GenericBackendV2(num_qubits=5) + + plot_gate_map(backend) + ``` + + ![../\_images/qiskit-visualization-plot\_gate\_map-1.png](/images/api/qiskit/1.0/qiskit-visualization-plot_gate_map-1.png) + + diff --git a/docs/api/qiskit/1.0/qiskit.visualization.plot_histogram.mdx b/docs/api/qiskit/1.0/qiskit.visualization.plot_histogram.mdx new file mode 100644 index 00000000000..02980900811 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.plot_histogram.mdx @@ -0,0 +1,78 @@ +--- +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 + + + Plot a histogram of input counts 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 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.4)")) – 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/1.0/qiskit-visualization-plot_histogram-1_00.png) + + ![../\_images/qiskit-visualization-plot\_histogram-1\_01.png](/images/api/qiskit/1.0/qiskit-visualization-plot_histogram-1_01.png) + + ![../\_images/qiskit-visualization-plot\_histogram-1\_02.png](/images/api/qiskit/1.0/qiskit-visualization-plot_histogram-1_02.png) + + diff --git a/docs/api/qiskit/1.0/qiskit.visualization.plot_state_city.mdx b/docs/api/qiskit/1.0/qiskit.visualization.plot_state_city.mdx new file mode 100644 index 00000000000..fd79c079808 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.plot_state_city.mdx @@ -0,0 +1,87 @@ +--- +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 + + + 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.4)")) – 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.4)")) – 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.4)") + + **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/1.0/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/1.0/qiskit-visualization-plot_state_city-2.png) + + diff --git a/docs/api/qiskit/1.0/qiskit.visualization.plot_state_hinton.mdx b/docs/api/qiskit/1.0/qiskit.visualization.plot_state_hinton.mdx new file mode 100644 index 00000000000..3b0f9574453 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.plot_state_hinton.mdx @@ -0,0 +1,60 @@ +--- +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 + + + 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.4)")) – 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.4)")) – 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.4)") + + **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/1.0/qiskit-visualization-plot_state_hinton-1.png) + + diff --git a/docs/api/qiskit/1.0/qiskit.visualization.plot_state_paulivec.mdx b/docs/api/qiskit/1.0/qiskit.visualization.plot_state_paulivec.mdx new file mode 100644 index 00000000000..318be4cb75c --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.plot_state_paulivec.mdx @@ -0,0 +1,90 @@ +--- +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 + + + 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.4)")) – 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.4)") + + **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/1.0/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/1.0/qiskit-visualization-plot_state_paulivec-2.png) + + diff --git a/docs/api/qiskit/1.0/qiskit.visualization.plot_state_qsphere.mdx b/docs/api/qiskit/1.0/qiskit.visualization.plot_state_qsphere.mdx new file mode 100644 index 00000000000..8afcaa870c7 --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.plot_state_qsphere.mdx @@ -0,0 +1,79 @@ +--- +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 + + + 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.4)")) – 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.4)") + + **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/1.0/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/1.0/qiskit-visualization-plot_state_qsphere-2.png) + + diff --git a/docs/api/qiskit/1.0/qiskit.visualization.timeline_drawer.mdx b/docs/api/qiskit/1.0/qiskit.visualization.timeline_drawer.mdx new file mode 100644 index 00000000000..ddff1bca2cb --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.timeline_drawer.mdx @@ -0,0 +1,319 @@ +--- +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 + + + 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 GenericBackendV2 + + qc = QuantumCircuit(2) + qc.h(0) + qc.cx(0,1) + + qc = transpile(qc, GenericBackendV2(5), scheduling_method='alap', layout_method='trivial') + draw(qc) + ``` + + ![../\_images/qiskit-visualization-timeline\_drawer-1.png](/images/api/qiskit/1.0/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 GenericBackendV2 + + qc = QuantumCircuit(2) + qc.h(0) + qc.cx(0,1) + + qc = transpile(qc, GenericBackendV2(5), scheduling_method='alap', layout_method='trivial') + draw(qc, style=IQXSimple()) + ``` + + ![../\_images/qiskit-visualization-timeline\_drawer-2.png](/images/api/qiskit/1.0/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 GenericBackendV2 + + qc = QuantumCircuit(2) + qc.h(0) + qc.cx(0,1) + + qc = transpile(qc, GenericBackendV2(5), scheduling_method='alap', layout_method='trivial') + draw(qc, style=IQXDebugging()) + ``` + + ![../\_images/qiskit-visualization-timeline\_drawer-3.png](/images/api/qiskit/1.0/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/1.0/qiskit.visualization.visualize_transition.mdx b/docs/api/qiskit/1.0/qiskit.visualization.visualize_transition.mdx new file mode 100644 index 00000000000..65288ac6a5b --- /dev/null +++ b/docs/api/qiskit/1.0/qiskit.visualization.visualize_transition.mdx @@ -0,0 +1,37 @@ +--- +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 + + + 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/1.0/qobj.mdx b/docs/api/qiskit/1.0/qobj.mdx new file mode 100644 index 00000000000..097d1aef2af --- /dev/null +++ b/docs/api/qiskit/1.0/qobj.mdx @@ -0,0 +1,51 @@ +--- +title: qobj +description: API reference for qiskit.qobj +in_page_toc_min_heading_level: 2 +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/1.0/qpy.mdx b/docs/api/qiskit/1.0/qpy.mdx new file mode 100644 index 00000000000..2cc8ae9b9c4 --- /dev/null +++ b/docs/api/qiskit/1.0/qpy.mdx @@ -0,0 +1,1145 @@ +--- +title: qpy +description: API reference for qiskit.qpy +in_page_toc_min_heading_level: 2 +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 + + + 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 + + + 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. + + * **version** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – + + The QPY format version to emit. By default this defaults to the latest supported format of [`QPY_VERSION`](#qiskit.qpy.QPY_VERSION "qiskit.qpy.QPY_VERSION"), however for compatibility reasons if you need to load the generated QPY payload with an older version of Qiskit you can also select an older QPY format version down to the minimum supported export version, which only can change during a Qiskit major version release, to generate an older QPY format version. You can access the current QPY version and minimum compatible version with [`qpy.QPY_VERSION`](#qiskit.qpy.QPY_VERSION "qiskit.qpy.QPY_VERSION") and [`qpy.QPY_COMPATIBILITY_VERSION`](#qiskit.qpy.QPY_COMPATIBILITY_VERSION "qiskit.qpy.QPY_COMPATIBILITY_VERSION") respectively. + + + If specified with an older version of QPY the limitations and potential bugs stemming from the QPY format at that version will persist. This should only be used if compatibility with loading the payload with an older version of Qiskit is necessary. + + + **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. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – When an unsupported version number is passed in for the `version` argument + + +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 + + + Errors raised by the qpy module. + + Set the error message. + + +#### qiskit.qpy.QPY\_VERSION + + + The current QPY format version as of this release. This is the default value of the `version` keyword argument on [`qpy.dump()`](#qiskit.qpy.dump "qiskit.qpy.dump") and also the upper bound for accepted values for the same argument. This is also the upper bond on the versions supported by [`qpy.load()`](#qiskit.qpy.load "qiskit.qpy.load"). + + **Type** + + [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + +#### qiskit.qpy.QPY\_COMPATIBILITY\_VERSION + + + The current minimum compatibility QPY format version. This is the minimum version that [`qpy.dump()`](#qiskit.qpy.dump "qiskit.qpy.dump") will accept for the `version` keyword argument. [`qpy.load()`](#qiskit.qpy.load "qiskit.qpy.load") will be able to load all released format versions of QPY (up until `QPY_VERSION`). + + **Type** + + [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + +### 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. + +If a feature being loaded is deprecated in the corresponding qiskit release, QPY will raise a [`QPYLoadingDeprecatedFeatureWarning`](#qiskit.qpy.QPYLoadingDeprecatedFeatureWarning "qiskit.qpy.QPYLoadingDeprecatedFeatureWarning") informing of the deprecation period and how the feature will be internally handled. + +#### QPYLoadingDeprecatedFeatureWarning + + + Visible deprecation warning for QPY loading functions without a stable point in the call stack. + + + + +## 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 11 + +Version 11 is identical to Version 10 except for the following. First, the names in the CUSTOM\_INSTRUCTION blocks have a suffix of the form `"_{uuid_hex}"` where `uuid_hex` is a uuid hexadecimal string such as returned by `UUID.hex`. For example: `"b3ecab5b4d6a4eb6bc2b2dbf18d83e1e"`. Second, it adds support for [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") objects. The base operation of an annotated operation is stored using the INSTRUCTION block, and an additional `type` value `'a'``is added to indicate that the custom instruction is an annotated operation. The list of modifiers are stored as instruction parameters using INSTRUCTION_PARAM, with an additional value ``'m'` is added to indicate that the parameter is of type `Modifier`. Each modifier is stored using the MODIFIER struct. + + + +#### MODIFIER + +This represents `Modifier` + +```python +struct { + char type; + uint32_t num_ctrl_qubits; + uint32_t ctrl_state; + double power; +} +``` + +This is sufficient to store different types of modifiers required for serializing objects of type [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). The field `type` is either `'i'`, `'c'` or `'p'`, representing whether the modifier is respectively an inverse modifier, a control modifier or a power modifier. In the second case, the fields `num_ctrl_qubits` and `ctrl_state` specify the control logic of the base operation, and in the third case the field `power` represents the power of the base operation. + + + +### 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](/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 [`SparsePauliOp`](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp"). + +```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/1.0/quantum_info.mdx b/docs/api/qiskit/1.0/quantum_info.mdx new file mode 100644 index 00000000000..b6e33579a8b --- /dev/null +++ b/docs/api/qiskit/1.0/quantum_info.mdx @@ -0,0 +1,890 @@ +--- +title: quantum_info +description: API reference for qiskit.quantum_info +in_page_toc_min_heading_level: 2 +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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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/1.0/result.mdx b/docs/api/qiskit/1.0/result.mdx new file mode 100644 index 00000000000..403623de8e9 --- /dev/null +++ b/docs/api/qiskit/1.0/result.mdx @@ -0,0 +1,152 @@ +--- +title: result +description: API reference for qiskit.result +in_page_toc_min_heading_level: 2 +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 + + + 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 + + + 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 + + + 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 + + + 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 or 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/1.0/scheduler.mdx b/docs/api/qiskit/1.0/scheduler.mdx new file mode 100644 index 00000000000..1701e9b704b --- /dev/null +++ b/docs/api/qiskit/1.0/scheduler.mdx @@ -0,0 +1,116 @@ +--- +title: scheduler +description: API reference for qiskit.scheduler +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit.scheduler +--- + + + + + + + +# Circuit Scheduler + + + +`qiskit.scheduler` + +A circuit scheduler compiles a circuit program to a pulse program. + +### ScheduleConfig + + + 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 + + + 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 + + + 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 + + + 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/1.0/synthesis.mdx b/docs/api/qiskit/1.0/synthesis.mdx new file mode 100644 index 00000000000..bcea081d130 --- /dev/null +++ b/docs/api/qiskit/1.0/synthesis.mdx @@ -0,0 +1,783 @@ +--- +title: synthesis +description: API reference for qiskit.synthesis +in_page_toc_min_heading_level: 2 +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 + + + 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 \times 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)")*\[*[*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*]] | np.ndarray\[*[*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*]*) – $n \times 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 the number of 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 + + + Synthesize linear reversible circuit for linear nearest-neighbor architectures using Kutin, Moulton, Smithline method. + + Synthesis algorithm for linear reversible circuits from \[1], section 7. This algorithm synthesizes any linear reversible circuit of $n$ qubits over a linear nearest-neighbor architecture using CX gates with depth at most $5n$. + + **Parameters** + + **mat** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")*\[*[*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*]*) – A boolean invertible matrix. + + **Returns** + + The synthesized quantum circuit. + + **Raises** + + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if `mat` is not invertible. + + **Return type** + + [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + + **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 + + + 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 [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate")s and phase gates ([`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate"), [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate") or [`ZGate`](qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate")). + + **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 + +### synth\_cx\_cz\_depth\_line\_my + + + 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. `mat_z[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.QuantumCircuit") + + **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) + 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 + + + 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, `cx` gates are applied so that a designated target bit contains the (partial) parity $\chi_y(x)$ where $y_i = 1$ if and only if $y'_i = 1$ for all $y' \in S$. If $S$ contains a single element $\{y'\}$, then $y = y'$, and the target bit contains the value $\chi_{y'}(x)$ as desired. + + Notably, rather than uncomputing this sequence of `cx` (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)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(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)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(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 in the Patel–Markov–Hayes algorithm. `section_size` must be a factor of the number of qubits. + + **Returns** + + The decomposed quantum circuit. + + **Raises** + + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – when dimensions of `cnots` and `angles` don’t align. + + **Return type** + + [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + + **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 + + + Synthesize a permutation circuit for a linear nearest-neighbor architecture using the Kutin, Moulton, Smithline method. + + This is the permutation synthesis algorithm from \[1], section 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** ([*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\[*[*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 position `1`, etc. + + **Returns** + + The synthesized quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + **References** + + 1. Samuel A. Kutin, David Petrie Moulton and Lawren M. Smithline. *Computation at a distance.*, [arXiv:quant-ph/0701194v1](https://arxiv.org/abs/quant-ph/0701194) + + +### synth\_permutation\_basic + + + 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** ([*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\[*[*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 position `1`, etc. + + **Returns** + + The synthesized quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + +### synth\_permutation\_acg + + + 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 Proposition 4.1 in reference \[1] with the detailed proof given in Theorem 2 in reference \[2] + + **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)")*] | np.ndarray\[*[*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 position `1`, etc. + + **Returns** + + The synthesized quantum circuit. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + **References** + + 1. N. Alon, F. R. K. Chung, and R. L. Graham. *Routing Permutations on Graphs Via Matchings.*, Proceedings of the Twenty-Fifth Annual ACM Symposium on Theory of Computing(1993). Pages 583–591. [(Extended abstract) 10.1145/167088.167239](https://doi.org/10.1145/167088.167239) + 2. N. Alon, F. R. K. Chung, and R. L. Graham. *Routing Permutations on Graphs Via Matchings.*, [(Full paper)](https://www.cs.tau.ac.il/~nogaa/PDFS/r.pdf) + + +## Clifford Synthesis + +### synth\_clifford\_full + + + Decompose a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") operator into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + + For $N \leq 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)") *| None*) – Optional, a synthesis method (`'AG'` or `'greedy'`). If set this overrides optimal decomposition for $N \leq 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 + + + Decompose a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") operator into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") based on Aaronson-Gottesman method \[1]. + + **Parameters** + + **clifford** ([*Clifford*](qiskit.quantum_info.Clifford "qiskit.quantum_info.operators.symplectic.clifford.Clifford")) – A Clifford operator. + + **Returns** + + A circuit implementation of the Clifford. + + **Return type** + + [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + + **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) + + +### synth\_clifford\_bm + + + Optimal CX-cost decomposition of a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") operator on 2 qubits or 3 qubits into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") based on the Bravyi-Maslov method \[1]. + + **Parameters** + + **clifford** ([*Clifford*](qiskit.quantum_info.Clifford "qiskit.quantum_info.operators.symplectic.clifford.Clifford")) – A Clifford operator. + + **Returns** + + A circuit implementation of the Clifford. + + **Raises** + + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if Clifford is on more than 3 qubits. + + **Return type** + + [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.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) + + +### synth\_clifford\_greedy + + + Decompose a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") operator into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") based on the greedy Clifford compiler that is described in Appendix A of Bravyi, Hu, Maslov and Shaydulin \[1]. + + This method typically yields better CX cost compared to the Aaronson-Gottesman method. + + Note that this function only implements the greedy Clifford compiler from Appendix A of \[1], and not the templates and symbolic Pauli gates optimizations that are mentioned in the same paper. + + **Parameters** + + **clifford** ([*Clifford*](qiskit.quantum_info.Clifford "qiskit.quantum_info.operators.symplectic.clifford.Clifford")) – A Clifford operator. + + **Returns** + + A circuit implementation of the Clifford. + + **Raises** + + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if symplectic Gaussian elimination fails. + + **Return type** + + [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + + **References** + + 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 + + + Synthesis of a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") into layers, it provides a similar decomposition to the synthesis described in Lemma 8 of Bravyi and Maslov \[1]. + + 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\[\[np.ndarray],* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – A function to decompose the CX sub-circuit. It gets as input a boolean invertible matrix, and outputs a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + * **cz\_synth\_func** (*Callable\[\[np.ndarray],* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – A function to decompose the CZ sub-circuit. It gets as input a boolean symmetric matrix, and outputs a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.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()`](#qiskit.synthesis.synth_cz_depth_line_mr "qiskit.synthesis.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") + + **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) + + +### synth\_clifford\_depth\_lnn + + + Synthesis of a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") into layers for linear-nearest neighbour connectivity. + + The depth of the synthesized n-qubit circuit is bounded by $7n+2$, which is not optimal. It should be replaced by a better algorithm that provides depth bounded by $7n-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") + + **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. 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 + + + Decompose a [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") element into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + + For $N \leq 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.operators.dihedral.dihedral.CNOTDihedral")) – A [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") element. + + **Returns** + + A circuit implementation of the [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") element. + + **Return type** + + [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.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 + + + Decompose a [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") element on a single qubit and two qubits into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). This decomposition has an optimal number of [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate")s. + + **Parameters** + + **elem** ([*CNOTDihedral*](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.operators.dihedral.dihedral.CNOTDihedral")) – A [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") element. + + **Returns** + + A circuit implementation of the [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") element. + + **Raises** + + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the element in not 1-qubit or 2-qubit [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral"). + + **Return type** + + [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + + **References** + + 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 + + + Decompose a [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") element into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + + Decompose a general [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") elements. The number of CX gates is not necessarily optimal. For a decomposition of a 1-qubit or 2-qubit element, call [`synth_cnotdihedral_two_qubits()`](#qiskit.synthesis.synth_cnotdihedral_two_qubits "qiskit.synthesis.synth_cnotdihedral_two_qubits"). + + **Parameters** + + **elem** ([*CNOTDihedral*](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.operators.dihedral.dihedral.CNOTDihedral")) – A [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") element. + + **Returns** + + A circuit implementation of the [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") element. + + **Raises** + + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the element could not be decomposed into a circuit. + + **Return type** + + [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + + **References** + + 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 + + + Synthesis of a stabilizer state into layers. + + It provides a similar decomposition to the synthesis described in Lemma 8 of reference \[1], 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.states.stabilizerstate.StabilizerState")) – A stabilizer state. + * **cz\_synth\_func** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)")*\[\[*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")*],* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")*]*) – A function to decompose the CZ sub-circuit. It gets as input a boolean symmetric matrix, and outputs a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + * **cz\_func\_reverse\_qubits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – `True` only if `cz_synth_func` is [`synth_cz_depth_line_mr()`](#qiskit.synthesis.synth_cz_depth_line_mr "qiskit.synthesis.synth_cz_depth_line_mr"), since this function returns a circuit that reverts the order of qubits. + * **validate** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True`, validates the synthesis process. + + **Returns** + + A circuit implementation of the stabilizer state. + + **Raises** + + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input is not a [`StabilizerState`](qiskit.quantum_info.StabilizerState "qiskit.quantum_info.StabilizerState"). + + **Return type** + + [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.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) + + +### synth\_stabilizer\_depth\_lnn + + + Synthesis of an n-qubit stabilizer state for linear-nearest neighbour connectivity, in 2-qubit depth $2n+2$ and two distinct CX layers, using [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate")s and phase gates ([`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate"), [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate") or [`ZGate`](qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate")). + + **Parameters** + + **stab** ([*StabilizerState*](qiskit.quantum_info.StabilizerState "qiskit.quantum_info.states.stabilizerstate.StabilizerState")) – A stabilizer state. + + **Returns** + + A circuit implementation of the stabilizer state. + + **Return type** + + [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.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. Dmitri Maslov, Martin Roetteler, *Shorter stabilizer circuits via Bruhat decomposition and quantum circuit transformations*, [arXiv:1705.09176](https://arxiv.org/abs/1705.09176). + + +### synth\_circuit\_from\_stabilizers + + + Synthesis of a circuit that generates a state stabilized by the stabilizers using Gaussian elimination with Clifford gates. If the stabilizers are underconstrained, and `allow_underconstrained` is `True`, the circuit will output one of the states stabilized by the stabilizers. Based on stim implementation. + + **Parameters** + + * **stabilizers** ([*Collection*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Collection "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – List of stabilizer strings + * **allow\_redundant** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Allow redundant stabilizers (i.e., some stabilizers can be products of the others) + * **allow\_underconstrained** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Allow underconstrained set of stabilizers (i.e., the stabilizers do not specify a unique state) + * **invert** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Return inverse circuit + + **Returns** + + A circuit that generates a state stabilized by `stabilizers`. + + **Raises** + + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the stabilizers are invalid, do not commute, or contradict each other, if the list is underconstrained and `allow_underconstrained` is `False`, or if the list is redundant and `allow_redundant` is `False`. + + **Return type** + + [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + + **References** + + 1. [https://github.com/quantumlib/Stim/blob/c0dd0b1c8125b2096cd54b6f72884a459e47fe3e/src/stim/stabilizers/conversions.inl#L469](https://github.com/quantumlib/Stim/blob/c0dd0b1c8125b2096cd54b6f72884a459e47fe3e/src/stim/stabilizers/conversions.inl#L469) + 2. [https://quantumcomputing.stackexchange.com/questions/12721/how-to-calculate-destabilizer-group-of-toric-and-other-codes](https://quantumcomputing.stackexchange.com/questions/12721/how-to-calculate-destabilizer-group-of-toric-and-other-codes) + + +## Discrete Basis Synthesis + +| | | +| --------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------- | +| [`SolovayKitaevDecomposition`](qiskit.synthesis.SolovayKitaevDecomposition "qiskit.synthesis.SolovayKitaevDecomposition")(\[...]) | The Solovay Kitaev discrete decomposition algorithm. | + +### generate\_basic\_approximations + + + Generates a list of `GateSequence`s with the gates in `basis_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 `GateSequence`s using the gates in `basis_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] + + +## Basis Change Synthesis + +### synth\_qft\_line + + + Synthesis of a QFT circuit for a linear nearest neighbor connectivity. Based on Fig 2.b in Fowler et al. \[1]. + + Note that this method *reverts* the order of qubits in the circuit, compared to the original [`QFT`](qiskit.circuit.library.QFT "qiskit.circuit.library.QFT") code. Hence, the default value of the `do_swaps` parameter is `True` since it produces a circuit with fewer CX gates. + + **Parameters** + + * **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – 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. + + **Returns** + + A circuit implementation of the QFT circuit. + + **Return type** + + [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + + **References** + + 1. A. G. Fowler, S. J. Devitt, and L. C. L. Hollenberg, *Implementation of Shor’s algorithm on a linear nearest neighbour qubit array*, Quantum Info. Comput. 4, 4 (July 2004), 237–251. [arXiv:quant-ph/0402196 \[quant-ph\]](https://arxiv.org/abs/quant-ph/0402196) + + +## Unitary Synthesis + +Decomposition of general $2^n \times 2^n$ unitary matrices for any number of qubits. + +### qs\_decomposition + + + 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 [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate")s 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`, [`CZGate`](qiskit.circuit.library.CZGate "qiskit.circuit.library.CZGate")s are left in the output. If desired these can be further decomposed to [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate")s. + * **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") + + **References** + + 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`](qiskit.synthesis.unitary.aqc#module-qiskit.synthesis.unitary.aqc "qiskit.synthesis.unitary.aqc") | Approximate Quantum Compiler (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$). | +| [`TwoQubitWeylDecomposition`](qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.TwoQubitWeylDecomposition")(unitary\_matrix, \*) | Two-qubit Weyl decomposition. | + +### two\_qubit\_cnot\_decompose + + + This is an instance of [`TwoQubitBasisDecomposer`](qiskit.synthesis.TwoQubitBasisDecomposer "qiskit.synthesis.TwoQubitBasisDecomposer") that always uses `cx` as the KAK gate for the basis decomposition. You can use this function as a quick access to `cx`-based 2-qubit decompositions. + + **Parameters** + + * **unitary** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") *or np.ndarray*) – The 4x4 unitary to synthesize. + * **basis\_fidelity** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *or None*) – If given the assumed fidelity for applications of [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate"). + * **approximate** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True` approximate if `basis_fidelity` is less than 1.0. + + **Returns** + + The synthesized circuit of the input unitary. + + **Return type** + + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + diff --git a/docs/api/qiskit/1.0/transpiler.mdx b/docs/api/qiskit/1.0/transpiler.mdx new file mode 100644 index 00000000000..eb5300a377b --- /dev/null +++ b/docs/api/qiskit/1.0/transpiler.mdx @@ -0,0 +1,985 @@ +--- +title: transpiler +description: API reference for qiskit.transpiler +in_page_toc_min_heading_level: 2 +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/1.0/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 GenericBackendV2 + +backend = GenericBackendV2(num_qubits=5) +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 [`GenericBackendV2`](qiskit.providers.fake_provider.GenericBackendV2 "qiskit.providers.fake_provider.GenericBackendV2") backend (equivalent to what is used internally by [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") with `backend=GenericBackendV2(5)` 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 GenericBackendV2 +backend = GenericBackendV2(5) + +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 GenericBackendV2 + +backend = GenericBackendV2(5) + +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/1.0/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. We can transpile the circuit to show what it will look like in the native gate set of the target IBM Quantum device (the [`GenericBackendV2`](qiskit.providers.fake_provider.GenericBackendV2 "qiskit.providers.fake_provider.GenericBackendV2") class generates a fake backend with a specified number of qubits for test purposes): + +```python +from qiskit import transpile +from qiskit import QuantumCircuit +from qiskit.providers.fake_provider import GenericBackendV2 + +backend = GenericBackendV2(5) + +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/1.0/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 GenericBackendV2 + backend = GenericBackendV2(5) + + 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/1.0/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/1.0/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 Fake5QV1 +backend = Fake5QV1() + +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/1.0/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 Fake5QV1 + > backend = Fake5QV1() + > + > 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/1.0/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 Fake5QV1 + > backend = Fake5QV1() + > + > 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/1.0/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 Fake5QV1 +backend = Fake5QV1() + +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/1.0/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") 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` in a heavy hex coupling map: + +![../\_images/transpiler-11.png](/images/api/qiskit/1.0/transpiler-11.png) + +```python +import matplotlib.pyplot as plt +from qiskit import QuantumCircuit, transpile +from qiskit.providers.fake_provider import GenericBackendV2 +from qiskit.transpiler import CouplingMap + +coupling_map = CouplingMap.from_heavy_hex(3) +backend = GenericBackendV2(coupling_map.size(), coupling_map=coupling_map) + +ghz = QuantumCircuit(15) +ghz.h(0) +ghz.cx(0, range(1, 15)) + +depths = [] +for i in range(100): + depths.append( + transpile( + ghz, + backend, + seed_transpiler=i, + 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/1.0/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/1.0/transpiler-13.png) + +```python +import matplotlib.pyplot as plt +from qiskit import QuantumCircuit, transpile +from qiskit.providers.fake_provider import GenericBackendV2 +backend = GenericBackendV2(16) + +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/1.0/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/1.0/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 GenericBackendV2 + +backend = GenericBackendV2(5) + +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/1.0/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/1.0/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 [`circuit.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. | + +### 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 + + + Exceptions raised during transpilation. + + Set the error message. + + +#### TranspilerAccessError + + + DEPRECATED: Exception of access error in the transpiler passes. + + Set the error message. + + +#### CouplingError + + + Base class for errors raised by the coupling graph object. + + Set the error message. + + +#### LayoutError + + + Errors raised by the layout object. + + Set the error message. + + +#### CircuitTooWideForTarget + + + Error raised if the circuit is too wide for the target. + + Set the error message. + + +#### InvalidLayoutError + + + Error raised when a user provided layout is invalid. + + Set the error message. + + diff --git a/docs/api/qiskit/1.0/transpiler_passes.mdx b/docs/api/qiskit/1.0/transpiler_passes.mdx new file mode 100644 index 00000000000..d12cf8b759c --- /dev/null +++ b/docs/api/qiskit/1.0/transpiler_passes.mdx @@ -0,0 +1,179 @@ +--- +title: passes +description: API reference for qiskit.transpiler.passes +in_page_toc_min_heading_level: 2 +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. | +| [`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. | + +## 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. | +| [`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. | +| [`OptimizeAnnotated`](qiskit.transpiler.passes.OptimizeAnnotated "qiskit.transpiler.passes.OptimizeAnnotated")(\*args, \*\*kwargs) | Optimization pass on circuits with annotated operations. | + +## 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. | + +### rzx\_templates + + + Convenience function to get the cost\_dict and templates for template matching. + + **Parameters** + + **template\_list** ([*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 instruction names. + + **Returns** + + Decomposition templates and cost values. + + **Return type** + + [*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)") + + +## 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 + +The synthesis transpiler plugin documentation can be found in the [`qiskit.transpiler.passes.synthesis.plugin`](transpiler_synthesis_plugins#module-qiskit.transpiler.passes.synthesis.plugin "qiskit.transpiler.passes.synthesis.plugin") page. + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`UnitarySynthesis`](qiskit.transpiler.passes.UnitarySynthesis "qiskit.transpiler.passes.UnitarySynthesis")(\*args, \*\*kwargs) | Synthesize gates according to their basis gates. | +| [`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. | +| [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.HLSConfig")(\[use\_default\_on\_unspecified]) | The high-level-synthesis config allows to specify a list of "methods" used by [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis") transformation pass to synthesize different types of higher-level objects. | +| [`SolovayKitaev`](qiskit.transpiler.passes.SolovayKitaev "qiskit.transpiler.passes.SolovayKitaev")(\*args, \*\*kwargs) | Approximately decompose 1q gates to a discrete basis using the Solovay-Kitaev algorithm. | + +## Post Layout (Post transpile qubit selection) + +| | | +| ---------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`VF2PostLayout`](qiskit.transpiler.passes.VF2PostLayout "qiskit.transpiler.passes.VF2PostLayout")(\*args, \*\*kwargs) | A pass for improving an existing 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. | +| [`FilterOpNodes`](qiskit.transpiler.passes.FilterOpNodes "qiskit.transpiler.passes.FilterOpNodes")(\*args, \*\*kwargs) | Remove all operations that match a filter function | + diff --git a/docs/api/qiskit/1.0/transpiler_plugins.mdx b/docs/api/qiskit/1.0/transpiler_plugins.mdx new file mode 100644 index 00000000000..e8754036d13 --- /dev/null +++ b/docs/api/qiskit/1.0/transpiler_plugins.mdx @@ -0,0 +1,164 @@ +--- +title: plugin +description: API reference for qiskit.transpiler.preset_passmanagers.plugin +in_page_toc_min_heading_level: 2 +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`, `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` | 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 an `entry-points` table in `pyproject.toml` for 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 +.. code-block:: toml +``` + +> \[project.entry-points.”qiskit.transpiler.layout”] “vf2” = “qiskit\_plugin\_pkg.module.plugin:VF2LayoutPlugin” + +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 + + + 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 + + + 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/1.0/transpiler_preset.mdx b/docs/api/qiskit/1.0/transpiler_preset.mdx new file mode 100644 index 00000000000..d8a82d9901b --- /dev/null +++ b/docs/api/qiskit/1.0/transpiler_preset.mdx @@ -0,0 +1,372 @@ +--- +title: preset_passmanagers +description: API reference for qiskit.transpiler.preset_passmanagers +in_page_toc_min_heading_level: 2 +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 + + + 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`, `coupling_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") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – 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'`, and `'sabre'`, representing [`TrivialLayout`](qiskit.transpiler.passes.TrivialLayout "qiskit.transpiler.passes.TrivialLayout"), [`DenseLayout`](qiskit.transpiler.passes.DenseLayout "qiskit.transpiler.passes.DenseLayout") and [`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 `'translator'`, `'synthesis'` representing [`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_method` argument. As this is custom for each unitary synthesis plugin refer to the plugin documentation for how to use this option. + + * **hls\_config** ([*HLSConfig*](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.HLSConfig")) – An optional configuration class [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + Get a pass manager that always raises an error if control flow is present in a given circuit. + + +### generate\_unroll\_3q + + + 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*](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.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 + + + 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 + + + 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 + + + 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 + + + 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*](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.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 + + + 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/1.0/transpiler_synthesis_plugins.mdx b/docs/api/qiskit/1.0/transpiler_synthesis_plugins.mdx new file mode 100644 index 00000000000..5d71b150df4 --- /dev/null +++ b/docs/api/qiskit/1.0/transpiler_synthesis_plugins.mdx @@ -0,0 +1,297 @@ +--- +title: plugin +description: API reference for qiskit.transpiler.passes.synthesis.plugin +in_page_toc_min_heading_level: 2 +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. + +## Synthesis Plugin API + +### Unitary Synthesis Plugin API + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------- | +| [`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 Plugin API + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------- | +| [`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. | +| [`high_level_synthesis_plugin_names`](qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names "qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names")(op\_name) | Return a list of plugin names installed for a given high level object name | + +## 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` table in `pyproject.toml` for the plugin package with the necessary entry points under the `qiskit.unitary_synthesis` namespace. For example: + +```python +[project.entry-points."qiskit.unitary_synthesis"] +"special" = "qiskit_plugin_pkg.module.plugin:SpecialUnitarySynthesis" +``` + +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 `options` 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` table in `pyproject.toml` for the plugin package with the necessary entry points under the `qiskit.synthesis` namespace. For example: + +```python +[project.entry-points."qiskit.synthesis"] +"clifford.special" = "qiskit_plugin_pkg.module.plugin:SpecialSynthesisClifford" +``` + +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 + + + +### Unitary Synthesis 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. + + + + + +### High-level Synthesis Plugins + +To use a high-level synthesis plugin, you first instantiate an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.HLSConfig") to store the names of the plugins to use for various high-level objects. For example: + +```python +HLSConfig(permutation=["acg"], clifford=["layers"], linear_function=["pmh"]) +``` + +creates a high-level synthesis configuration that uses the `acg` plugin for synthesizing [`PermutationGate`](qiskit.circuit.library.PermutationGate "qiskit.circuit.library.PermutationGate") objects, the `layers` plugin for synthesizing [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") objects, and the `pmh` plugin for synthesizing [`LinearFunction`](qiskit.circuit.library.LinearFunction "qiskit.circuit.library.LinearFunction") objects. The keyword arguments are the [`Operation.name`](qiskit.circuit.Operation#name "qiskit.circuit.Operation.name") fields of the relevant objects. For example, all [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") operations have the [`name`](qiskit.circuit.Operation#name "qiskit.circuit.Operation.name") `clifford`, so this is used as the keyword argument. You can specify any keyword argument here that you have installed plugins to handle, including custom user objects if you have plugins installed for them. See [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.HLSConfig") for more detail on alternate formats for configuring the plugins within each argument. + +For each high-level object, the list of given plugins are tried in sequence until one of them succeeds (in the example above, each list only contains a single plugin). In addition to specifying a plugin by its name, you can instead pass a `(name, options)` tuple, where the second element of the tuple is a dictionary containing options for the plugin. + +Once created you then pass this [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.HLSConfig") object into the `hls_config` argument 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") which will use the specified plugins as part of the larger compilation workflow. + +To get a list of installed high level synthesis plugins for any given [`Operation.name`](qiskit.circuit.Operation#name "qiskit.circuit.Operation.name"), you can use the [`high_level_synthesis_plugin_names()`](qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names "qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names") function, passing the desired `name` as the argument: + +```python +high_level_synthesis_plugin_names("clifford") +``` + +will return a list of all the installed Clifford synthesis plugins. + +## Available Plugins + +High-level synthesis plugins that are directly available in Qiskit include plugins for synthesizing [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") objects, [`LinearFunction`](qiskit.circuit.library.LinearFunction "qiskit.circuit.library.LinearFunction") objects, and [`PermutationGate`](qiskit.circuit.library.PermutationGate "qiskit.circuit.library.PermutationGate") objects. Some of these plugins implicitly target all-to-all connectivity. This is not a practical limitation since [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis") typically runs before layout and routing, which will ensure that the final circuit adheres to the device connectivity by inserting additional SWAP gates. A good example is the permutation synthesis plugin `ACGSynthesisPermutation` which can synthesize any permutation with at most 2 layers of SWAP gates. On the other hand, some plugins implicitly target linear connectivity. Typically, the synthesizing circuits have larger depth and the number of gates, however no additional SWAP gates would be inserted if the following layout pass chose a consecutive line of qubits inside the topology of the device. A good example of this is the permutation synthesis plugin `KMSSynthesisPermutation` which can synthesize any permutation of `n` qubits in depth `n`. Typically, it is difficult to know in advance which of the two approaches: synthesizing circuits for all-to-all connectivity and inserting SWAP gates vs. synthesizing circuits for linear connectivity and inserting less or no SWAP gates lead a better final circuit, so it likely makes sense to try both and see which gives better results. Finally, some plugins can target a given connectivity, and hence should be run after the layout is set. In this case the synthesized circuit automatically adheres to the topology of the device. A good example of this is the permutation synthesis plugin `TokenSwapperSynthesisPermutation` which is able to synthesize arbitrary permutations with respect to arbitrary coupling maps. For more detail, please refer to description of each individual plugin. + +Below are the synthesis plugin classes available in Qiskit. These classes should not be used directly, but instead should be used through the plugin interface documented above. The classes are listed here to ease finding the documentation for each of the included plugins and to ease the comparison between different synthesis methods for a given object. + + + +### Unitary Synthesis Plugins + + + + + +#### AQC Synthesis Plugin (in [`qiskit.transpiler.passes.synthesis.aqc_plugin`](#module-qiskit.transpiler.passes.synthesis.aqc_plugin "qiskit.transpiler.passes.synthesis.aqc_plugin")) + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------- | +| [`AQCSynthesisPlugin`](qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin "qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin")() | An AQC-based Qiskit unitary synthesis plugin. | + + + + + +#### Unitary Synthesis Plugin (in [`qiskit.transpiler.passes.synthesis.unitary_synthesis`](#module-qiskit.transpiler.passes.synthesis.unitary_synthesis "qiskit.transpiler.passes.synthesis.unitary_synthesis")) + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------- | +| [`DefaultUnitarySynthesis`](qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis "qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis")() | The default unitary synthesis plugin. | + + + + + +#### Solovay-Kitaev Synthesis Plugin (in [`qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis`](#module-qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis "qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis")) + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------- | +| [`SolovayKitaevSynthesis`](qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis "qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis")() | A Solovay-Kitaev Qiskit unitary synthesis plugin. | + +### High Level Synthesis + +For each high-level object we give a table that lists all of its plugins available directly in Qiskit. We include the name of the plugin, the class of the plugin, the targeted connectivity map and optionally additional information. Recall the plugins should be used via the previously described [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.HLSConfig"), for example: + +```python +HLSConfig(permutation=["kms"]) +``` + +creates a high-level synthesis configuration that uses the `kms` plugin for synthesizing [`PermutationGate`](qiskit.circuit.library.PermutationGate "qiskit.circuit.library.PermutationGate") objects – i.e. those with `name = "permutation"`. In this case, the plugin name is “kms”, the plugin class is [`KMSSynthesisPermutation`](qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation "qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation"). This particular synthesis algorithm created a circuit adhering to the linear nearest-neighbor connectivity. + + + + + +#### High Level Synthesis Plugins + +##### Clifford Synthesis + +| Plugin name | Plugin class | Targeted connectivity | Description | +| ----------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------- | --------------------------------------------------------------------- | +| `"ag"` | [`AGSynthesisClifford`](qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford "qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford") | all-to-all | greedily optimizes CX-count | +| `"bm"` | [`BMSynthesisClifford`](qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford "qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford") | all-to-all | optimal count for n=2,3; used in `"default"` for n=2,3 | +| `"greedy"` | [`GreedySynthesisClifford`](qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford "qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford") | all-to-all | greedily optimizes CX-count; used in `"default"` for n>=4 | +| `"layers"` | [`LayerSynthesisClifford`](qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford "qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford") | all-to-all | | +| `"lnn"` | [`LayerLnnSynthesisClifford`](qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford "qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford") | linear | many CX-gates but guarantees CX-depth of at most 7\*n+2 | +| `"default"` | [`DefaultSynthesisClifford`](qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford "qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford") | all-to-all | usually best for optimizing CX-count (and optimal CX-count for n=2,3) | + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ---------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`AGSynthesisClifford`](qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford "qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford")() | Clifford synthesis plugin based on the Aaronson-Gottesman method. | +| [`BMSynthesisClifford`](qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford "qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford")() | Clifford synthesis plugin based on the Bravyi-Maslov method. | +| [`GreedySynthesisClifford`](qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford "qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford")() | Clifford synthesis plugin based on the greedy synthesis Bravyi-Hu-Maslov-Shaydulin method. | +| [`LayerSynthesisClifford`](qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford "qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford")() | Clifford synthesis plugin based on the Bravyi-Maslov method to synthesize Cliffords into layers. | +| [`LayerLnnSynthesisClifford`](qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford "qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford")() | Clifford synthesis plugin based on the Bravyi-Maslov method to synthesize Cliffords into layers, with each layer synthesized adhering to LNN connectivity. | +| [`DefaultSynthesisClifford`](qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford "qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford")() | The default clifford synthesis plugin. | + +##### Linear Function Synthesis + +| Plugin name | Plugin class | Targeted connectivity | Description | +| ----------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------- | ----------------------------------------------------- | +| `"kms"` | [`KMSSynthesisLinearFunction`](qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction "qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction") | linear | many CX-gates but guarantees CX-depth of at most 5\*n | +| `"pmh"` | [`PMHSynthesisLinearFunction`](qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction "qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction") | all-to-all | greedily optimizes CX-count; used in `"default"` | +| `"default"` | [`DefaultSynthesisLinearFunction`](qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction "qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction") | all-to-all | best for optimizing CX-count | + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------- | +| [`KMSSynthesisLinearFunction`](qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction "qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction")() | Linear function synthesis plugin based on the Kutin-Moulton-Smithline method. | +| [`PMHSynthesisLinearFunction`](qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction "qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction")() | Linear function synthesis plugin based on the Patel-Markov-Hayes method. | +| [`DefaultSynthesisLinearFunction`](qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction "qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction")() | The default linear function synthesis plugin. | + +##### Permutation Synthesis + +| Plugin name | Plugin class | Targeted connectivity | Description | +| ----------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------- | -------------------------------------------------------- | +| `"basic"` | [`BasicSynthesisPermutation`](qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation "qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation") | all-to-all | optimal SWAP-count; used in `"default"` | +| `"acg"` | [`ACGSynthesisPermutation`](qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation "qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation") | all-to-all | guarantees SWAP-depth of at most 2 | +| `"kms"` | [`KMSSynthesisPermutation`](qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation "qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation") | linear | many SWAP-gates, but guarantees SWAP-depth of at most n | +| `"token_swapper"` | [`TokenSwapperSynthesisPermutation`](qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation "qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation") | any | greedily optimizes SWAP-count for arbitrary connectivity | +| `"default"` | [`BasicSynthesisPermutation`](qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation "qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation") | all-to-all | best for optimizing SWAP-count | + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------- | +| [`BasicSynthesisPermutation`](qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation "qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation")() | The permutation synthesis plugin based on sorting. | +| [`ACGSynthesisPermutation`](qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation "qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation")() | The permutation synthesis plugin based on the Alon, Chung, Graham method. | +| [`KMSSynthesisPermutation`](qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation "qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation")() | The permutation synthesis plugin based on the Kutin, Moulton, Smithline method. | +| [`TokenSwapperSynthesisPermutation`](qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation "qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation")() | The permutation synthesis plugin based on the token swapper algorithm. | + diff --git a/docs/api/qiskit/1.0/utils.mdx b/docs/api/qiskit/1.0/utils.mdx new file mode 100644 index 00000000000..1df583b4865 --- /dev/null +++ b/docs/api/qiskit/1.0/utils.mdx @@ -0,0 +1,500 @@ +--- +title: utils +description: API reference for qiskit.utils +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit.utils +--- + + + + + + + +# Utilities + + + +`qiskit.utils` + +## Deprecations + +### add\_deprecation\_to\_docstring + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + +## SI unit conversion + +### apply\_prefix + + + 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 + + + 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)")] + + +## Class tools + +### wrap\_method + + + 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. + + +## Multiprocessing + +### local\_hardware\_info + + + 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 + + + Checks whether the current process is the main one + + +A helper function for calling a custom function with python [`ProcessPoolExecutor`](https://docs.python.org/3/library/concurrent.futures.html#concurrent.futures.ProcessPoolExecutor "(in Python v3.12)"). Tasks can be executed in parallel using this function. + +### parallel\_map + + + 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. + + **Examples** + + ```python + import time + from qiskit.utils import parallel_map + def func(_): + time.sleep(0.1) + return 0 + parallel_map(func, list(range(10))); + ``` + + + + +## Optional Dependency Checkers + +Qiskit has several features that are enabled only if certain *optional* dependencies are satisfied. This module, [`qiskit.utils.optionals`](#module-qiskit.utils.optionals "qiskit.utils.optionals"), has 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.github.io/qiskit-aer/](https://qiskit.github.io/qiskit-aer/)> provides high-performance simulators for the quantum circuits constructed within Qiskit. | +| **qiskit.utils.optionals.HAS\_IBMQ** | The `Qiskit IBMQ Provider` is used for accessing IBM Quantum hardware in the IBM cloud. | +| **qiskit.utils.optionals.HAS\_IGNIS** | `Qiskit Ignis` provides tools for quantum hardware verification, noise characterization, and error correction. | +| **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) is a constraint satisfaction problem solver, used in the [`CSPLayout`](qiskit.transpiler.passes.CSPLayout "qiskit.transpiler.passes.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` 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-community.github.io/qiskit-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` 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` use regularisation methods from [Scikit Learn](https://scikit-learn.org/stable/). | +| **qiskit.utils.optionals.HAS\_SKQUANT** | Some of the optimisers in `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` 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.utils.optionals.HAS\_Z3** | [Z3](https://github.com/Z3Prover/z3) is a theorem prover, used in the `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 +``` + +#### LazyDependencyManager + + + 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 + + + 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 + + + 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 + + + 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 + + + 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 + + + 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. + + + +#### LazyImportTester + + + 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. + + +#### LazySubprocessTester + + + 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/1.0/visualization.mdx b/docs/api/qiskit/1.0/visualization.mdx new file mode 100644 index 00000000000..1597ea05b64 --- /dev/null +++ b/docs/api/qiskit/1.0/visualization.mdx @@ -0,0 +1,233 @@ +--- +title: visualization +description: API reference for qiskit.visualization +in_page_toc_min_heading_level: 2 +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/1.0/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/1.0/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/1.0/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/1.0/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/1.0/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/1.0/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. | + +## 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. | + +## 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 + + + For visualization specific errors. + + Set the error message. + + diff --git a/docs/api/qiskit/_package.json b/docs/api/qiskit/_package.json index de9636b477d..04867d65c59 100644 --- a/docs/api/qiskit/_package.json +++ b/docs/api/qiskit/_package.json @@ -1,4 +1,4 @@ { "name": "qiskit", - "version": "1.0.2" + "version": "1.1.0" } diff --git a/docs/api/qiskit/_toc.json b/docs/api/qiskit/_toc.json index 19bdb89a92e..2e2f64a4955 100644 --- a/docs/api/qiskit/_toc.json +++ b/docs/api/qiskit/_toc.json @@ -15,22 +15,10 @@ "title": "Module overview", "url": "/api/qiskit/circuit" }, - { - "title": "AncillaQubit", - "url": "/api/qiskit/qiskit.circuit.AncillaQubit" - }, - { - "title": "AncillaRegister", - "url": "/api/qiskit/qiskit.circuit.AncillaRegister" - }, { "title": "AnnotatedOperation", "url": "/api/qiskit/qiskit.circuit.AnnotatedOperation" }, - { - "title": "Bit", - "url": "/api/qiskit/qiskit.circuit.Bit" - }, { "title": "BreakLoopOp", "url": "/api/qiskit/qiskit.circuit.BreakLoopOp" @@ -39,18 +27,6 @@ "title": "CircuitInstruction", "url": "/api/qiskit/qiskit.circuit.CircuitInstruction" }, - { - "title": "ClassicalRegister", - "url": "/api/qiskit/qiskit.circuit.ClassicalRegister" - }, - { - "title": "Clbit", - "url": "/api/qiskit/qiskit.circuit.Clbit" - }, - { - "title": "CommutationChecker", - "url": "/api/qiskit/qiskit.circuit.CommutationChecker" - }, { "title": "ContinueLoopOp", "url": "/api/qiskit/qiskit.circuit.ContinueLoopOp" @@ -63,14 +39,6 @@ "title": "ControlledGate", "url": "/api/qiskit/qiskit.circuit.ControlledGate" }, - { - "title": "ControlModifier", - "url": "/api/qiskit/qiskit.circuit.ControlModifier" - }, - { - "title": "Delay", - "url": "/api/qiskit/qiskit.circuit.Delay" - }, { "title": "EquivalenceLibrary", "url": "/api/qiskit/qiskit.circuit.EquivalenceLibrary" @@ -95,10 +63,6 @@ "title": "InstructionSet", "url": "/api/qiskit/qiskit.circuit.InstructionSet" }, - { - "title": "InverseModifier", - "url": "/api/qiskit/qiskit.circuit.InverseModifier" - }, { "title": "Operation", "url": "/api/qiskit/qiskit.circuit.Operation" @@ -115,26 +79,10 @@ "title": "ParameterVector", "url": "/api/qiskit/qiskit.circuit.ParameterVector" }, - { - "title": "PowerModifier", - "url": "/api/qiskit/qiskit.circuit.PowerModifier" - }, { "title": "QuantumCircuit", "url": "/api/qiskit/qiskit.circuit.QuantumCircuit" }, - { - "title": "QuantumRegister", - "url": "/api/qiskit/qiskit.circuit.QuantumRegister" - }, - { - "title": "Qubit", - "url": "/api/qiskit/qiskit.circuit.Qubit" - }, - { - "title": "Register", - "url": "/api/qiskit/qiskit.circuit.Register" - }, { "title": "SwitchCaseOp", "url": "/api/qiskit/qiskit.circuit.SwitchCaseOp" @@ -185,10 +133,6 @@ "title": "AND", "url": "/api/qiskit/qiskit.circuit.library.AND" }, - { - "title": "Barrier", - "url": "/api/qiskit/qiskit.circuit.library.Barrier" - }, { "title": "C3SXGate", "url": "/api/qiskit/qiskit.circuit.library.C3SXGate" @@ -433,10 +377,6 @@ "title": "MCXVChain", "url": "/api/qiskit/qiskit.circuit.library.MCXVChain" }, - { - "title": "Measure", - "url": "/api/qiskit/qiskit.circuit.library.Measure" - }, { "title": "MSGate", "url": "/api/qiskit/qiskit.circuit.library.MSGate" @@ -529,10 +469,6 @@ "title": "RealAmplitudes", "url": "/api/qiskit/qiskit.circuit.library.RealAmplitudes" }, - { - "title": "Reset", - "url": "/api/qiskit/qiskit.circuit.library.Reset" - }, { "title": "RGate", "url": "/api/qiskit/qiskit.circuit.library.RGate" @@ -1197,6 +1133,10 @@ "title": "EchoRZXWeylDecomposition", "url": "/api/qiskit/qiskit.transpiler.passes.EchoRZXWeylDecomposition" }, + { + "title": "ElidePermutations", + "url": "/api/qiskit/qiskit.transpiler.passes.ElidePermutations" + }, { "title": "EnlargeWithAncilla", "url": "/api/qiskit/qiskit.transpiler.passes.EnlargeWithAncilla" @@ -1337,6 +1277,10 @@ "title": "RemoveFinalMeasurements", "url": "/api/qiskit/qiskit.transpiler.passes.RemoveFinalMeasurements" }, + { + "title": "RemoveFinalReset", + "url": "/api/qiskit/qiskit.transpiler.passes.RemoveFinalReset" + }, { "title": "RemoveResetInZeroState", "url": "/api/qiskit/qiskit.transpiler.passes.RemoveResetInZeroState" @@ -1389,6 +1333,10 @@ "title": "SolovayKitaevSynthesis", "url": "/api/qiskit/qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis" }, + { + "title": "StarPreRouting", + "url": "/api/qiskit/qiskit.transpiler.passes.StarPreRouting" + }, { "title": "StochasticSwap", "url": "/api/qiskit/qiskit.transpiler.passes.StochasticSwap" @@ -1517,10 +1465,18 @@ "title": "BackendEstimator", "url": "/api/qiskit/qiskit.primitives.BackendEstimator" }, + { + "title": "BackendEstimatorV2", + "url": "/api/qiskit/qiskit.primitives.BackendEstimatorV2" + }, { "title": "BackendSampler", "url": "/api/qiskit/qiskit.primitives.BackendSampler" }, + { + "title": "BackendSamplerV2", + "url": "/api/qiskit/qiskit.primitives.BackendSamplerV2" + }, { "title": "BaseEstimatorV1", "url": "/api/qiskit/qiskit.primitives.BaseEstimatorV1" @@ -1573,10 +1529,18 @@ "title": "Sampler", "url": "/api/qiskit/qiskit.primitives.Sampler" }, + { + "title": "SamplerPubResult", + "url": "/api/qiskit/qiskit.primitives.SamplerPubResult" + }, { "title": "SamplerResult", "url": "/api/qiskit/qiskit.primitives.SamplerResult" }, + { + "title": "Shaped", + "url": "/api/qiskit/qiskit.primitives.Shaped" + }, { "title": "StatevectorEstimator", "url": "/api/qiskit/qiskit.primitives.StatevectorEstimator" @@ -2209,6 +2173,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/assembler.mdx b/docs/api/qiskit/assembler.mdx index cee333c62c8..f6e6bb4861c 100644 --- a/docs/api/qiskit/assembler.mdx +++ b/docs/api/qiskit/assembler.mdx @@ -18,11 +18,11 @@ python_api_name: qiskit.assembler `qiskit.assembler` -## Circuit Assembler +## Functions ### assemble\_circuits - + Assembles a list of circuits into a qobj that can be run on the backend. **Parameters** @@ -61,11 +61,9 @@ python_api_name: qiskit.assembler ``` -## Schedule Assembler - ### assemble\_schedules - + Assembles a list of schedules into a qobj that can be run on the backend. **Parameters** @@ -125,11 +123,9 @@ python_api_name: qiskit.assembler ``` -## Disassembler - ### disassemble - + Disassemble a qobj and return the circuits or pulse schedules, run\_config, and user header. @@ -172,7 +168,7 @@ python_api_name: qiskit.assembler ``` -## RunConfig +## Classes | | | | -------------------------------------------------------------------------------------------------------------- | ---------------------------- | diff --git a/docs/api/qiskit/circuit.mdx b/docs/api/qiskit/circuit.mdx index 9aafee2987b..7084c4d0cb7 100644 --- a/docs/api/qiskit/circuit.mdx +++ b/docs/api/qiskit/circuit.mdx @@ -10,26 +10,45 @@ python_api_name: qiskit.circuit - + -# Quantum Circuits +# Quantum circuit model `qiskit.circuit` -## Overview +The fundamental element of quantum computing is the *quantum circuit*. This is a computational routine that can be run, one shot at a time, on a quantum processing unit (QPU). A circuit will act on a predefined amount of quantum data (in Qiskit, we only directly support qubits) with unitary operations (gates), measurements and resets. In addition, a quantum circuit can contain operations on classical data, including real-time computations and control-flow constructs, which are executed by the controllers of the QPU. -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. + + You may wish to skip the introductory material and jump directly to: -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: + * [the API overview of the whole circuit module](#circuit-module-api) + * [the detailed discussion about how circuits are represented](#circuit-repr) + * the core [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") class for how to build and query circuits + * [information on construction custom instructions](#circuit-custom-gates) + * [ways to work with circuit-level objects](#circuit-working-with) + * [discussion of Qiskit conventions for circuits, matrices and state labelling](#circuit-conventions) + + +Circuits are at a low level of abstraction when building up quantum programs. They are the construct that is used to build up to higher levels of abstraction, such as the [primitives of quantum computation](primitives#qiskit-primitives), which accumulate data from many shots of quantum-circuit execution, along with advanced error-mitigation techniques and measurement optimizations, into well-typed classical data and error statistics. + +In Qiskit, circuits can be defined in one of two regimes: + +* an *abstract* circuit, which is defined in terms of *virtual qubits* and arbitrary high-level operations, like encapsulated algorithms and user-defined gates. +* a *physical* circuit, which is defined in terms of the *hardware qubits* of one particular backend, and contains only operations that this backend natively supports. You might also see this concept referred to as an *ISA circuit*. + +You convert from an abstract circuit to a physical circuit by using [Qiskit’s transpilation package](transpiler#qiskit-transpiler), of which the top-level access point is [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile"). + +In Qiskit, a quantum circuit 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 Greenberger–Horne–Zeilinger (GHZ) state defined as: $$ -|\psi\rangle = \left(|000\rangle+|111\rangle\right)/\sqrt{2} +|\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>. @@ -44,265 +63,759 @@ circ.draw('mpl') ![../\_images/circuit-1.png](/images/api/qiskit/circuit-1.png) -## Supplementary Information + -### Quantum Circuit with conditionals +## Circuit concepts and definitions -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. +There is a lot of specialized terminology around quantum circuits. Much of this is common in quantum-computing literature, while some is more specific to quantum software packages, and a small amount specific to Qiskit. This is an alphabetical listing of some of the important concepts as a quick reference, but does not go into detail of the foundational concepts. Consider using the [IBM Quantum Learning platform](https://learning.quantum.ibm.com/) if you want to start from the beginning. -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. +**abstract circuit** -```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') -``` +A *circuit* defined in terms of abstract mathematical operations and *virtual qubits*. This is typically how you think about quantum algorithms; an abstract circuit can be made up of completely arbitrary unitary operations, measurements, and potentially *real-time classical computation*, with no restrictions about which qubits can interact with each other. -![../\_images/circuit-2.png](/images/api/qiskit/circuit-2.png) +You turn an abstract circuit into a *physical circuit* by using [Qiskit’s transpilation package](transpiler#qiskit-transpiler). -```python -from qiskit.providers.basic_provider import BasicSimulator -backend = BasicSimulator() -tqc = transpile(qc, backend) -counts = backend.run(tqc).result().get_counts() +**ancilla qubit** -print(counts) -``` +An extra qubit that is used to help implement operations on other qubits, but whose final state is not important for the program. -```python -{'0': 524, '1': 500} -``` +**circuit** -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$. +A computational routine the defines a single execution to be taken on a QPU. This can either be an *abstract circuit* or a *physical circuit*. -```python -from qiskit import transpile, QuantumRegister, ClassicalRegister, QuantumCircuit +**clbit** -qr = QuantumRegister(1) -cr = ClassicalRegister(1) -qc = QuantumCircuit(qr, cr) -qc.h(0) -qc.measure(0, 0) +A Qiskit-specific abbreviation meaning a single classical bit of data. -qc.x(0).c_if(cr, 0) -qc.measure(0, 0) +**gate** -qc.draw('mpl') -``` +A *unitary operation* on one or more qubits. -![../\_images/circuit-3.png](/images/api/qiskit/circuit-3.png) +**hardware qubit** -```python -from qiskit.providers.basic_provider import BasicSimulator -backend = BasicSimulator() -tqc = transpile(qc, backend) -counts = backend.run(tqc).result().get_counts() +The representation of a single qubit on a particular *QPU*. A hardware qubit has some physical quantum-mechanical system backing it, such as superconducting circuits; unlike a *virtual qubit*, it has particular coupling constraints and only certain gates can be applied to certain groups of hardware qubits. -print(counts) -``` +Qiskit does not distinguish *logical qubits* from any individual *physical qubits* when talking about hardware qubits. A QPU may implement its hardware qubits as logical qubits, where each hardware qubit comprises many physical qubits that are controlled and error-corrected opaquely to Qiskit by the control electronics. More likely, for near-term applications, a QPU will be directly exposing its physical qubits as the hardware qubits for Qiskit to reason about. -```python -{'1': 1024} -``` +Both physical and logical qubits will have coupling constraints between them, only permit certain quantum operations on them, and have scheduling concerns between them. Qiskit abstracts these concerns together in the concept of hardware qubits. In the early days of quantum error correction, particular backends may let you access their qubit resources either as high-level logical qubits or as low-level physical qubits through Qiskit. -### Quantum Circuit Properties +**instruction set architecture (ISA)** -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. +The abstract model of which operations are available on which sets of *hardware qubits* on one particular *QPU*. For example, one QPU may allow $\sqrt X$ and $R_Z$ operations on all single hardware qubits, and $CX$ operations on certain pairs of hardware qubits. -Consider the following circuit: +**logical qubit** -```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') -``` +A collection of several *physical qubits* that are controlled together by a QPU (from the user’s perspective) to apply real-time quantum error correction. A logical qubit is a type of *hardware qubit* for Qiskit. -![../\_images/circuit-4.png](/images/api/qiskit/circuit-4.png) +**measurement** -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: +The act of extracting one classical bit of a data from a single qubit state. This is an irreversible operation, and usually destroys entanglement and phase coherence between the target qubit and the rest of the system. -```python -qc.width() -``` +**physical circuit** -```python -12 -``` +A *circuit* defined in terms of *hardware qubits* and only the quantum operations available in a particular *QPU’s* *ISA*. Physical circuits are tied to one particular QPU architecture, and will not run on other incompatible architectures. You may also hear this referred to as an *ISA circuit*. -We can also just get the number of qubits directly: +You typically get a physical circuit by using [Qiskit’s transpilation routines](transpiler#qiskit-transpiler) on an *abstract circuit* that you constructed. -```python -qc.num_qubits -``` +**physical qubit** + +A controllable two-level quantum system. This is literally one “physics” qubit, such as a transmon or the electronic state of a trapped ion. A QPU may expose this directly as its *hardware qubit*, or combine several physical qubits into a *logical qubit*. + +**quantum processing unit (QPU)** + +Analogous to a CPU in classical computing or a GPU in graphics processing, a QPU is the hardware that runs quantum operations on quantum data. You can always expect a QPU that uses the *circuit* model of computation to be able to perform some set of *gates*, and *measurement* operations. Depending on the particular technology, they also may be able to run some real-time classical computations as well, such as classical control flow and bitwise calculations on classical data. + +**qubit** + +The basic unit of quantum information. + +**real-time classical computation** + +Any classical computation that can happen within the execution of a single shot of a *circuit*, where the results of the classical computation can affect later execution of the circuit. The amount of real-time classical computation available with particular *QPU*s will vary significantly dependent on many factors, such as the controlling electronics and the qubit technology in use. You should consult your hardware vendor’s documentation for more information on this. + +**unitary operation** + +A reversible operation on a quantum state. All quantum *gates* are unitary operations (by definition). + +**virtual qubit** + +An abstract, mathematical *qubit* used to build an *abstract circuit*. Virtual qubits are how one typically thinks about quantum algorithms at a high level; we assume that all quantum gates are valid on all virtual qubits, and all virtual qubits are always connected to every other virtual qubit. + +When mapping to hardware, virtual qubits must be assigned to *hardware qubits*. This mapping need not be one-to-one. Typically, one virtual qubit will need to be swapped from one hardware qubit to another over the course of a circuit execution in order to satisfy coupling constraints of the underlying QPU. It is not strictly necessary for all virtual qubits used in a circuit to be mapped to a physical qubit at any given point in a *physical circuit*; it could be that a virtual qubit is measured (collapsing its state) and then never used again, so a new virtual qubit could take its place. Evaluating these conditions to map a virtual circuit to a physical circuit is the job of [Qiskit’s transpilation package](transpiler#qiskit-transpiler). + + + + + +## API overview of qiskit.circuit + +All objects here are described in more detail, and in their greater context in the following sections. This section provides an overview of the API elements documented here. + +The principal class is [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), which has its own documentation page, including an in-depth section on building circuits. Quantum data and the simplest classical data are represented by “bits” and “registers”: + +* **[`Bit`](#qiskit.circuit.Bit "qiskit.circuit.Bit"), an atom of data** + + * [`Qubit`](#qiskit.circuit.Qubit "qiskit.circuit.Qubit") + * [`Clbit`](#qiskit.circuit.Clbit "qiskit.circuit.Clbit") + * [`AncillaQubit`](#qiskit.circuit.AncillaQubit "qiskit.circuit.AncillaQubit") + +* **[`Register`](#qiskit.circuit.Register "qiskit.circuit.Register"), a collection of bits** + + * [`QuantumRegister`](#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") + * [`ClassicalRegister`](#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") + * [`AncillaRegister`](#qiskit.circuit.AncillaRegister "qiskit.circuit.AncillaRegister") + +Within a circuit, each complete [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") is made up of an [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") (which might be an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"), a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"), or some other subclass) and the qubit and clbit operands. The core base classes here are: + +* [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction"), an operation and its operands + +* [`InstructionSet`](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet"), a temporary handle to a slice of circuit data + +* **[`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation"), any abstract mathematical object or hardware instruction** + + * **[`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"), a subclass with applied abstract modifiers** + + * [`InverseModifier`](#qiskit.circuit.InverseModifier "qiskit.circuit.InverseModifier") + * [`ControlModifier`](#qiskit.circuit.ControlModifier "qiskit.circuit.ControlModifier") + * [`PowerModifier`](#qiskit.circuit.PowerModifier "qiskit.circuit.PowerModifier") + +The most common concrete subclass of the minimal, abstract [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") interface is the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"). While [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") can include abstract mathematical objects, an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") is something that could conceivably run directly on hardware. This is in turn subclassed by [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") and [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") that further add unitarity and controlled semantics on top: + +* [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"), representing a hardware-based instruction +* [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"), representing a hardware instruction that is unitary +* [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate"), representing a gate with control structure. + +Qiskit includes a large library of standard gates and circuits, which is documented in [`qiskit.circuit.library`](circuit_library#module-qiskit.circuit.library "qiskit.circuit.library"). Many of these are declared as Python-object singletons. The machinery for this is described in detail in [`qiskit.circuit.singleton`](circuit_singleton#module-qiskit.circuit.singleton "qiskit.circuit.singleton"), of which the main classes are each a singleton form of the standard instruction–gate hierarchy: + +* [`SingletonInstruction`](circuit_singleton#qiskit.circuit.singleton.SingletonInstruction "qiskit.circuit.singleton.SingletonInstruction") +* [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") +* [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + +Some instructions are particularly special in that they affect the control flow or data flow of the circuit. The top-level ones are: + +* [`Barrier`](#qiskit.circuit.Barrier "qiskit.circuit.Barrier"), to mark parts of the circuit that should be optimized independently + +* [`Delay`](#qiskit.circuit.Delay "qiskit.circuit.Delay"), to insert a real-time wait period + +* [`Measure`](#qiskit.circuit.Measure "qiskit.circuit.Measure"), to measure a [`Qubit`](#qiskit.circuit.Qubit "qiskit.circuit.Qubit") into a [`Clbit`](#qiskit.circuit.Clbit "qiskit.circuit.Clbit") + +* [`Reset`](#qiskit.circuit.Reset "qiskit.circuit.Reset"), to irreversibly reset a qubit to the $\lvert0\rangle$ state + +* [`Store`](#qiskit.circuit.Store "qiskit.circuit.Store"), to write a real-time classical expression to a storage location + +* **[`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp"), which has specific subclasses:** + + * [`BreakLoopOp`](qiskit.circuit.BreakLoopOp "qiskit.circuit.BreakLoopOp"), to break out of the nearest containing loop + * [`ContinueLoopOp`](qiskit.circuit.ContinueLoopOp "qiskit.circuit.ContinueLoopOp"), to move immediately to the next iteration of the containing loop + * [`ForLoopOp`](qiskit.circuit.ForLoopOp "qiskit.circuit.ForLoopOp"), to loop over a fixed range of values + * [`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp"), to conditionally enter one of two subcircuits + * [`SwitchCaseOp`](qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp"), to conditionally enter one of many subcicuits + * [`WhileLoopOp`](qiskit.circuit.WhileLoopOp "qiskit.circuit.WhileLoopOp"), to repeat a subcircuit until a condition is falsified. + +[Circuits can include classical expressions that are evaluated in real time](#circuit-repr-real-time-classical), while the QPU is executing a single shot of the circuit. These are primarily documented in the module documentation of [`qiskit.circuit.classical`](circuit_classical#module-qiskit.circuit.classical "qiskit.circuit.classical"). You might be particularly interested in the base classes (which are not exposed from the [`qiskit.circuit`](#module-qiskit.circuit "qiskit.circuit") root): + +* [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var"), a typed classical storage location in a circuit +* [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr"), a real-time-evaluated expression +* [`Type`](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type"), the classical type of an expression. + +In addition to this real-time expression evaluation, which is limited by classical hardware representations of data, Qiskit has the concept of “compile-time” parametrization, which is done in abstract symbolic algebra. These are typically used to represent gate angles in high-level algorithms that might want to perform numerical derivatives, but they are an older part of Qiskit than the real-time evaluation, so are still used in some places to do general parametrization. The main related classes are: + +* [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter"), the atom of compile-time expressions +* [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression"), a symbolic calculation on parameters +* [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector"), a convenience collection of many [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")s + +The [`qiskit.circuit`](#module-qiskit.circuit "qiskit.circuit") module also exposes some calculation classes that work with circuits to assist compilation workflows. These include: + +* [`EquivalenceLibrary`](qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary"), a database of decomposition relations between gates and circuits +* [`SessionEquivalenceLibrary`](#qiskit.circuit.SessionEquivalenceLibrary "qiskit.circuit.SessionEquivalenceLibrary"), a mutable instance of [`EquivalenceLibrary`](qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary") which is used by default by the compiler’s [`BasisTranslator`](qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator"). + +There is also a utility for generating random circuits: + +* [`random.random_circuit()`](#qiskit.circuit.random.random_circuit "qiskit.circuit.random.random_circuit") + +Finally, the circuit module has its own exception class, to indicate when things went wrong in circuit-specific manners: + +* [`CircuitError`](#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") + + + +## Representation of circuits in Qiskit + +The main user-facing class for representing circuits is [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). This can be either an abstract circuit or a physical circuit. There is much more information about the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") class itself and the multitude of available methods on it in its class documentation. + +Internally, a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") contains the qubits, classical bits, compile-time parameters, real-time variables, and other tracking information about the data it acts on and how it is parametrized. It then contains a sequence of [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s, which contain the particular operation (gate, measurement, etc) and its operands (the qubits and classical bits). + +### Bits and registers + +Qubits and classical bits are represented by a shared base [`Bit`](#qiskit.circuit.Bit "qiskit.circuit.Bit") type, which is just intended to be a “type tag”; the classes have no behavior other than being immutable objects: + +#### Bit + + + 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. + + +#### Qubit + + + Bases: [`Bit`](#qiskit.circuit.Bit "qiskit.circuit.bit.Bit") + + Implement a quantum bit. + + +#### Clbit + + + Bases: [`Bit`](#qiskit.circuit.Bit "qiskit.circuit.bit.Bit") + + Implement a classical bit. + + +Qubits and clbits are instantiated by users with no arguments, such as by `Qubit()`. Bits compare equal if they are the same Python object, or if they were both created by a register of the same name and size, and they refer to the same index within that register. There is also a special type tag for “ancilla” qubits, but this is little used in the current state of Qiskit: + +#### AncillaQubit + + + Bases: [`Qubit`](#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") + + A qubit used as ancillary qubit. + + +A collection bits of the same type can be encapsulated in a register of the matching type. The base functionality is in a base class that is not directly instantiated: + +#### Register + + + 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**](#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if both the `size` and `bits` arguments are provided, or if neither are. + * [**CircuitError**](#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `size` is not valid. + * [**CircuitError**](#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `name` is not a valid name according to the OpenQASM spec. + * [**CircuitError**](#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `bits` contained duplicated bits. + * [**CircuitError**](#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `bits` contained bits of an incorrect type. + + ##### index + + + Find the index of the provided bit within this register. + + + ##### name + + + Get the register name. + + + ##### size + + + Get the register size. + + + +Each of the defined bit subtypes has an associated register, which have the same constructor signatures, methods and properties as the base class: + +#### QuantumRegister + + + Bases: [`Register`](#qiskit.circuit.Register "qiskit.circuit.register.Register") + + Implement a quantum register. + + +#### ClassicalRegister + + + Bases: [`Register`](#qiskit.circuit.Register "qiskit.circuit.register.Register") + + Implement a classical register. + + +#### AncillaRegister + + + Bases: [`QuantumRegister`](#qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") + + Implement an ancilla register. + + +A common way to instantiate several bits at once is to create a register, such as by `QuantumRegister("my_qreg", 5)`. This has the advantage that you can give that collection of bits a name, which will appear during circuit visualizations ([`QuantumCircuit.draw()`](qiskit.circuit.QuantumCircuit#draw "qiskit.circuit.QuantumCircuit.draw")) and exports to interchange languages (see [`qasm2`](qasm2#module-qiskit.qasm2 "qiskit.qasm2") and [`qasm3`](qasm3#module-qiskit.qasm3 "qiskit.qasm3")). You can also pass a name and a list of pre-constructed bits, but this creates an “aliasing register”, which are very poorly supported on hardware. + +Circuits track registers, but registers themselves impart almost no behavioral differences on circuits. The only exception is that [`ClassicalRegister`](#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")s can be implicitly cast to unsigned integers for use in conditional comparisons of [control flow operations](#circuit-control-flow-repr). + +Classical registers and bits were the original way of representing classical data in Qiskit, and remain the most supported currently. Longer term, the data model is moving towards a more complete and strongly typed representation of a range of classical data (see [Real-time classical computation](#circuit-repr-real-time-classical)), but you will still very commonly use classical bits in current Qiskit. + +### Instruction contexts + +The scalar type of the [`QuantumCircuit.data`](qiskit.circuit.QuantumCircuit#data "qiskit.circuit.QuantumCircuit.data") sequence is the “instruction context” object, [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction"). This is essentially just a data class that contains a representation of what is to be done (its [`operation`](qiskit.circuit.CircuitInstruction#operation "qiskit.circuit.CircuitInstruction.operation")), and the data it acts on (the [`qubits`](qiskit.circuit.CircuitInstruction#qubits "qiskit.circuit.CircuitInstruction.qubits") and [`clbits`](qiskit.circuit.CircuitInstruction#clbits "qiskit.circuit.CircuitInstruction.clbits")). + +| | | +| --------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") | A single instruction in a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), comprised of the `operation` and various operands. | + +Programmatically, this class is actually implemented in Rust and is a constructed handle to internal data within Rust space. Mutations to instances of this class will not be reflected in the circuit. In general, you cannot mutate instruction contexts that are already in the circuit directly; the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") interface is designed for storing and building circuits, while the [transpiler and its passes](transpiler#qiskit-transpiler), and its intermediate [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") representation, are where you should look for an interface to mutate circuits. + +The [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") methods that add instructions to circuits (such as [`append()`](qiskit.circuit.QuantumCircuit#append "qiskit.circuit.QuantumCircuit.append"), and all the helper standard-gate methods) return an [`InstructionSet`](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet"), which is a handle to several [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s simultaneously. + +| | | +| ------------------------------------------------------------------------------------------------------------- | ------------------------------------------- | +| [`InstructionSet`](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet")(\*\[, resource\_requester]) | Instruction collection, and their contexts. | + +This [`InstructionSet`](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") is now little used in Qiskit. It provides a very minimal set of methods to perform post-append mutations on instructions (which *will* be propagated to the circuit), but these are now discouraged and you should use the alternatives noted in those methods. + + + +### Operations, instructions and gates + +Within a [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction"), the minimal interface that any operation must fulfill is [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation"). This is a *very* high level view, and only usable for abstract circuits. The main purpose of treating operations as [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") is to allow arbitrary mathematical objects (such as [`quantum_info.Operator`](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) to be added to abstract circuits directly. + +| | | +| -------------------------------------------------------------------- | ---------------------------- | +| [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation")() | Quantum operation interface. | + +Most operations, including all operations on physical circuits, are instances of the more concretely defined [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"). This represents any instruction that some QPU might be able to carry out natively, such as [`Measure`](#qiskit.circuit.Measure "qiskit.circuit.Measure"). [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") need not be unitary (much as [`Measure`](#qiskit.circuit.Measure "qiskit.circuit.Measure") isn’t); an instruction is specifically unitary if it is a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). + +| | | +| ---------------------------------------------------------------------------------------------------------------- | ---------------------------- | +| [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction")(name, num\_qubits, num\_clbits, params) | Generic quantum instruction. | + +[`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction")s can be near arbitrary, provided they only act on [`Qubit`](#qiskit.circuit.Qubit "qiskit.circuit.Qubit")s and [`Clbit`](#qiskit.circuit.Clbit "qiskit.circuit.Clbit")s, and are parametrized by their [`params`](qiskit.circuit.Instruction#params "qiskit.circuit.Instruction.params"); they should not attempt to “close over” outer circuit registers, or use hidden parameters inside themselves. [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction")s can be related to other circuits to provide a decompositions by using their [`Instruction.definition`](qiskit.circuit.Instruction#definition "qiskit.circuit.Instruction.definition") attribute, which provides a local, one-off decomposition. This can be in whatever basis set of operations is most convenient to you, as long as the definitions of all contained gates have some topological order; that is, you cannot use a gate in a definition it its own definition depends on the parent. If the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") should be considered entirely opaque to optimizers, its [`definition`](qiskit.circuit.Instruction#definition "qiskit.circuit.Instruction.definition") can be `None`. See [Creating custom instructions](#circuit-custom-gates) for more detail. + +The [`params`](qiskit.circuit.Instruction#params "qiskit.circuit.Instruction.params") of an instruction can technically be arbitrary, but in general you should attempt to stick to parametrizations in terms of real numbers, wherever possible. Qiskit itself breaks this rule in many places, and you will find all sorts of unusual types in [`Instruction.params`](qiskit.circuit.Instruction#params "qiskit.circuit.Instruction.params") fields, but these are an annoying source of bugs because they often imply the need for type-aware special casing. If your instruction is parametrized in terms of angles, you will be able to reliably use [compile-time parametrization in it](#circuit-compile-time-parameters), and it will integrate well with [`QuantumCircuit.assign_parameters()`](qiskit.circuit.QuantumCircuit#assign_parameters "qiskit.circuit.QuantumCircuit.assign_parameters"). + +While [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") is not necessarily unitary, its subclass [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") implies unitarity, and adds [`to_matrix()`](qiskit.circuit.Gate#to_matrix "qiskit.circuit.Gate.to_matrix") and [`control()`](qiskit.circuit.Gate#control "qiskit.circuit.Gate.control") methods to all the methods inherited from [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"). + +| | | +| --------------------------------------------------------------------------------------------- | ------------- | +| [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate")(name, num\_qubits, params\[, label, ...]) | Unitary gate. | + +[`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") inherits all the methods for [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") and all the same considerations about its [`params`](qiskit.circuit.Instruction#params "qiskit.circuit.Instruction.params") and [`definition`](qiskit.circuit.Instruction#definition "qiskit.circuit.Instruction.definition") field, except of course that [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate")s cannot act on any classical resources. + +[`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") instances can (and should) have a base [`definition`](qiskit.circuit.Instruction#definition "qiskit.circuit.Instruction.definition"), but you can also specify several different decompositions in different bases by using an [`EquivalenceLibrary`](qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary"). + +Subclassing [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"), Qiskit has a special [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") class as well. This class is the base of many standard-library gates that are controlled (such as `CXGate`), which is where you are most likely to encounter it: + +| | | +| -------------------------------------------------------------------------------------------------------------------- | ------------------------ | +| [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate")(name, num\_qubits, params\[, ...]) | Controlled unitary gate. | + +Each of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"), [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") and [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") has a corresponding singleton type, built using the machinery described in [`qiskit.circuit.singleton`](circuit_singleton#module-qiskit.circuit.singleton "qiskit.circuit.singleton"). The module-level documentation contains full details, along with descriptions of [`SingletonInstruction`](circuit_singleton#qiskit.circuit.singleton.SingletonInstruction "qiskit.circuit.singleton.SingletonInstruction"), [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") and [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate"). From a user’s perspective, little changes based on whether the base class is a singleton or not; the intention always remains that you should call [`to_mutable()`](qiskit.circuit.Instruction#to_mutable "qiskit.circuit.Instruction.to_mutable") first if you need to get a safe-to-mutate owned copy of an instruction (you cannot assume that an arbitrary instruction is mutable), and while direct [`type`](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)") inspection is discouraged, if you do need it, the reliable way to find the “base” type of a potentially singleton instruction is to use [`base_class`](qiskit.circuit.Instruction#base_class "qiskit.circuit.Instruction.base_class"). + +[`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") uses the same mechanisms as [subclassing gates](#circuit-custom-gates) to define a fixed, lazy synthesis for itself. This is naturally not hardware-aware, and harder to hook into the synthesis routines of the compiler, but works better as a concrete [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") that could potentially be run natively on hardware. For cases where synthesis and abstract optimization is more important, Qiskit offers a composable class called [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"), which tracks “gate modifiers” (of which [`ControlModifier`](#qiskit.circuit.ControlModifier "qiskit.circuit.ControlModifier") is one) to apply to the inner [`base_op`](qiskit.circuit.AnnotatedOperation#base_op "qiskit.circuit.AnnotatedOperation.base_op"). + +| | | +| ------------------------------------------------------------------------------------------------------------------ | -------------------- | +| [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")(base\_op, modifiers) | Annotated operation. | + +The available modifiers for [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") are: + +#### InverseModifier + + + Inverse modifier: specifies that the operation is inverted. + + +#### ControlModifier + + + Control modifier: specifies that the operation is controlled by `num_ctrl_qubits` and has control state `ctrl_state`. + + +#### PowerModifier + + + Power modifier: specifies that the operation is raised to the power `power`. + + +For information on how to create custom gates and instructions, including how to build one-off objects, and re-usable parametric gates via subclassing, see [Creating custom instructions](#circuit-custom-gates) below. The Qiskit circuit library in [`qiskit.circuit.library`](circuit_library#module-qiskit.circuit.library "qiskit.circuit.library") contains many predefined gates and circuits for you to use. + +### Built-in special instructions + +Qiskit contains a few [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") classes that are in some ways “special”. These typically have special handling in circuit code, in the transpiler, or the models of hardware. These are all generally instructions you might already be familiar with. + +Measurements in Qiskit are of a single [`Qubit`](#qiskit.circuit.Qubit "qiskit.circuit.Qubit") into a single [`Clbit`](#qiskit.circuit.Clbit "qiskit.circuit.Clbit"). These are the two that the instruction is applied to. Measurements are in the computational basis. + +#### Measure + + + Bases: [`SingletonInstruction`](circuit_singleton#qiskit.circuit.singleton.SingletonInstruction "qiskit.circuit.singleton.SingletonInstruction") + + Quantum measurement in the computational basis. + + **Parameters** + + **label** – optional string label for this instruction. + + +Related to measurements, there is a [`Reset`](#qiskit.circuit.Reset "qiskit.circuit.Reset") operation, which produces no classical data but instructs hardware to return the qubit to the $\lvert0\rangle$ state. This is assumed to happen incoherently and to collapse any entanglement. + +#### Reset + + + Bases: [`SingletonInstruction`](circuit_singleton#qiskit.circuit.singleton.SingletonInstruction "qiskit.circuit.singleton.SingletonInstruction") + + Incoherently reset a qubit to the $\lvert0\rangle$ state. + + **Parameters** + + **label** – optional string label of this instruction. + + +Hardware can be instructed to apply a real-time idle period on a given qubit. A scheduled circuit (see [`qiskit.transpiler`](transpiler#module-qiskit.transpiler "qiskit.transpiler")) will include all the idle times on qubits explicitly in terms of this [`Delay`](#qiskit.circuit.Delay "qiskit.circuit.Delay"). + +#### Delay + + + Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + + Do nothing and just delay/wait/idle for a specified duration. + + **Parameters** + + * **duration** – the length of time of the duration. Given in units of `unit`. + * **unit** – the unit of the duration. Must be `"dt"` or an SI-prefixed seconds unit. + + +The [`Barrier`](#qiskit.circuit.Barrier "qiskit.circuit.Barrier") instruction can span an arbitrary number of qubits and clbits, and is a no-op in hardware. During transpilation and optimization, however, it blocks any optimizations from “crossing” the barrier; that is, in: ```python -12 +from qiskit.circuit import QuantumCircuit + +qc = QuantumCircuit(1) +qc.x(0) +qc.barrier() +qc.x(0) ``` - - 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 forbidden for the optimizer to cancel out the two $X$ instructions. + +#### Barrier + + + Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + + 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. + + This will also appear in visualizations as a visual marker. + + **Parameters** + + * **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of qubits for the barrier. + * **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – the optional label of this barrier. + + +The [`Store`](#qiskit.circuit.Store "qiskit.circuit.Store") instruction is particularly special, in that it allows writing the result of a [real-time classical computation expression](#circuit-repr-real-time-classical) (an [`expr.Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")) in a local classical variable (a [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")). It takes *neither* [`Qubit`](#qiskit.circuit.Qubit "qiskit.circuit.Qubit") nor [`Clbit`](#qiskit.circuit.Clbit "qiskit.circuit.Clbit") operands, but has an explicit [`lvalue`](#qiskit.circuit.Store.lvalue "qiskit.circuit.Store.lvalue") and [`rvalue`](#qiskit.circuit.Store.rvalue "qiskit.circuit.Store.rvalue"). + +#### Store + + + Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + + A manual storage of some classical value to a classical memory location. + + This is a low-level primitive of the classical-expression handling (similar to how [`Measure`](#qiskit.circuit.Measure "qiskit.circuit.Measure") is a primitive for quantum measurement), and is not safe for subclassing. + + **Parameters** + + * **lvalue** ([*expr.Expr*](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")) – the memory location being stored into. + * **rvalue** ([*expr.Expr*](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")) – the expression result being stored. + + ##### lvalue + + + Get the l-value [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") node that is being stored to. + + + ##### rvalue + + + Get the r-value [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") node that is being written into the l-value. + + + + + +### Real-time classical computation + + + **[`qiskit.circuit.classical`](circuit_classical#module-qiskit.circuit.classical "qiskit.circuit.classical")** + + Module-level documentation for how the variable-, expression- and type-systems work, the objects used to represent them, and the classical operations available. + + **[Working with real-time typed classical data](qiskit.circuit.QuantumCircuit#circuit-real-time-methods)** + + The [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") methods for working with these variables in the context of a single circuit. -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"): +Qiskit has rudimentary low-level support for representing real-time classical computations, which happen during the QPU execution and affect the results. We are still relatively early into hardware support for these concepts as well, so beware that you will need to work closely with your hardware provider’s documentation to get the best use out of any real-time classical computation. -```python -qc.count_ops() -``` +These real-time calculations are represented by the expression and type system in [`qiskit.circuit.classical`](circuit_classical#module-qiskit.circuit.classical "qiskit.circuit.classical"). At a high level, all real-time expressions are represented by an [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") node, which is part of an expression “tree” representation, which has a well-defined `Type` associated with it at every level. See the module-level documentation for much more detail on the internal representations of these classes. -```python -OrderedDict([('cx', 8), ('h', 5), ('x', 3), ('swap', 3)]) -``` +The result of a real-time [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") can be used directly in certain places. Currently this is limited to conditions of [`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp") and [`WhileLoopOp`](qiskit.circuit.WhileLoopOp "qiskit.circuit.WhileLoopOp"), and the target of [`SwitchCaseOp`](qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp"). The result can also be stored in a typed classical storage location, using the [`Store`](#qiskit.circuit.Store "qiskit.circuit.Store") instruction (or its [`QuantumCircuit.store()`](qiskit.circuit.QuantumCircuit#store "qiskit.circuit.QuantumCircuit.store") constructor), backed by a [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node. -We can also get just the raw count of operations by computing the circuits [`QuantumCircuit.size()`](qiskit.circuit.QuantumCircuit#size "qiskit.circuit.QuantumCircuit.size"): +A circuit can contain manual classical storage locations, represented internally by the [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node of the [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") tree. These have an attached classical type (like any other expression). These can either be declared and initialized within each execution of the circuit ([`add_var()`](qiskit.circuit.QuantumCircuit#add_var "qiskit.circuit.QuantumCircuit.add_var")), or be inputs to the circuit ([`add_input()`](qiskit.circuit.QuantumCircuit#add_input "qiskit.circuit.QuantumCircuit.add_input")). -```python -qc.size() -``` + -```python -19 -``` +### Compile-time parametrization -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. +Various parametric [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances in Qiskit can be parametrized in ways that are designed to be resolved at compile time. These are characterized by the use of the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") and [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") classes. -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: +| | | +| ------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------- | +| [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")(name, \*\[, uuid]) | A compile-time symbolic parameter. | +| [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")(symbol\_map, expr) | ParameterExpression class to enable creating expressions of Parameters. | -![../\_images/depth.gif](/images/api/qiskit/depth.gif) +The main way that this differs from the `expr.Var` variables used in real-time classical computation is that [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") is a symbolic representation of a mathematical expression. The semantics of the expression are those of regular mathematics over the continuous real numbers (and, in limited cases, over the complex numbers). In contrast, [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") is a handle to a variable stored on a classical computer, such as a floating-point value or an fixed-width integer, which are always discrete. -We can verify our graphical result using [`QuantumCircuit.depth()`](qiskit.circuit.QuantumCircuit#depth "qiskit.circuit.QuantumCircuit.depth"): +In other words, you can expect [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") to do symbolic simplifications that are valid in mathematics, such as simplifying $(x + y - x) / y \to 1$. Such a simplification is not valid in floating-point arithmetic, and [`expr.Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") will not do this. -```python -qc.depth() -``` +The “compile-time” part of these parameters means that you typically will want to “assign” values to the parameters before sending the circuit for execution. These parameters can typically be used anywhere that expects a mathematical angle (like a rotation gate’s parameters), with the caveat that hardware will usually require them to be assigned to a proper classically typed value before execution. You can do this assignment using [`QuantumCircuit.assign_parameters()`](qiskit.circuit.QuantumCircuit#assign_parameters "qiskit.circuit.QuantumCircuit.assign_parameters"). + +You may want to use many parameters that are related to each other. To make this easier (and to avoid you needing to come up with many names), you can use the convenience constructor [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector"). The elements of the vector are all valid [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances. + +| | | +| ----------------------------------------------------------------------------------------------------- | -------------------------------------------------------------- | +| [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector")(name\[, length]) | ParameterVector class to quickly generate lists of parameters. | + + + +### Control flow in circuits + +Within [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), classical control flow is represented by specific [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction")s, which are subclasses of [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp"). + +| | | +| -------------------------------------------------------------------------------------------------- | ---------------------------------------------------------- | +| [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp")(\*args, \*\*kwargs) | Abstract class to encapsulate all control flow operations. | + +These control-flow operations ([`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp"), [`WhileLoopOp`](qiskit.circuit.WhileLoopOp "qiskit.circuit.WhileLoopOp"), [`SwitchCaseOp`](qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp") and [`ForLoopOp`](qiskit.circuit.ForLoopOp "qiskit.circuit.ForLoopOp")) all have specific state that defines the branching conditions and strategies, but contain all the different subcircuit blocks that might be entered in their [`blocks`](qiskit.circuit.ControlFlowOp#blocks "qiskit.circuit.ControlFlowOp.blocks") property. + +| | | +| ----------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`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. | +| [`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`. | +| [`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`. | + +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. 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. + +In addition to the block-structure control-flow operations, there are also two special instructions that affect the flow of control when within loops. These correspond to typical uses of the `break` and `continue` statements in classical programming languages. + +| | | +| --------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------- | +| [`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 classes representations are documented here, but please note that manually constructing these classes is a low-level operation that we do not expect users to need to do frequently. + + Users should read [Adding control flow to circuits](qiskit.circuit.QuantumCircuit#circuit-control-flow-methods) for the recommended workflows for building control-flow-enabled circuits. + + +Since [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") subclasses are also [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") subclasses, this means that the way they are stored in [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") instances has them “applied” to a sequence of qubits and clbits in its [`qubits`](qiskit.circuit.CircuitInstruction#qubits "qiskit.circuit.CircuitInstruction.qubits") and [`clbits`](qiskit.circuit.CircuitInstruction#clbits "qiskit.circuit.CircuitInstruction.clbits") attributes. This can lead to subtle data-coherence problems: the [`Qubit`](#qiskit.circuit.Qubit "qiskit.circuit.Qubit") and [`Clbit`](#qiskit.circuit.Clbit "qiskit.circuit.Clbit") objects used inside the subcircuit blocks of the control-flow ops will not necessarily be identical to the corresponding objects in the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction"). Any code that consumes control-flow operations in Qiskit needs to be aware of this; within a subcircuit, you should treat `subcircuit.qubits[i]` as if it were really `outer_instruction.qubits[i]`, and so on. You can generate an easy lookup table for this by doing: ```python -9 +cf_instruction: CircuitInstruction = ... +cf_operation: ControlFlowOp = cf_instruction.operation +for block in blocks: + # Mappings of "inner" qubits/clbits to the outer ones. + qubit_map = dict(zip(block.qubits, cf_instruction.qubits)) + clbit_map = dict(zip(block.clbits, cf_instruction.clbits)) + + # ... do something with `block` ... ``` -## 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") | 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. | - -### Annotated Operations - -| | | -| ----------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------- | -| [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")(base\_op, modifiers) | Annotated operation. | -| [`InverseModifier`](qiskit.circuit.InverseModifier "qiskit.circuit.InverseModifier")() | Inverse modifier: specifies that the operation is inverted. | -| [`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`. | - -### 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. | +Remember that you will need to propagate this information if you recurse into subblocks of control-flow operations. -The [`SwitchCaseOp`](qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp") also understands a special value: +All the subcircuit blocks in a [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") are required to contain the same numbers of [`Qubit`](#qiskit.circuit.Qubit "qiskit.circuit.Qubit")s and [`Clbit`](#qiskit.circuit.Clbit "qiskit.circuit.Clbit")s, referring to the same outer bits in the same order, such that the `zip` loop given in the code block above works. The inner-circuit [`Bit`](#qiskit.circuit.Bit "qiskit.circuit.Bit") objects do not need to be literally the same objects. When using the control-flow builder interface (which, it cannot be stressed enough, is *highly* recommended for users), the builders will arrange that the inner bit objects *are* identical to the outer bit objects; the `qubit_map` in the code block above will always be a mapping `{x: x}`, but if you are consuming the blocks, you should be prepared for the case that the mapping is required. + +Any [`ClassicalRegister`](#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")s used in a control-flow subcircuit must also be present in all containing blocks (*i.e.* any containing control-flow operations, and the outermost circuit), and all blocks in the same [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") need to contain the same registers. Again, the builder interface will arrange for this to be the case (or produce an eager error if they cannot). + +When the low-level construction is being used the inner [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") blocks must manually close over any outer-scope [real-time classical computation variables](#circuit-repr-real-time-classical) that they use. This is marked by these being in the [`iter_captured_vars()`](qiskit.circuit.QuantumCircuit#iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars") iterator for that block. Libraries constructing these blocks manually will need to track these captures when building control-flow circuit blocks and add them to the block using [`add_capture()`](qiskit.circuit.QuantumCircuit#add_capture "qiskit.circuit.QuantumCircuit.add_capture") (or the `captures` constructor argument), but user code will typically use the control-flow builder interface, which handles this automatically. + +Consult [the control-flow construction documentation](qiskit.circuit.QuantumCircuit#circuit-control-flow-methods) for more information on how to build circuits with control flow. + + + +## Creating custom instructions + +If you wish to create simple one-off instructions or gates that will be added to a circuit, and the blocks are just being used for visualization or grouping purposes, the easiest way to create a custom instruction or gate is simply to build its definition as a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), and then use its [`to_instruction()`](qiskit.circuit.QuantumCircuit#to_instruction "qiskit.circuit.QuantumCircuit.to_instruction") or [`to_gate()`](qiskit.circuit.QuantumCircuit#to_gate "qiskit.circuit.QuantumCircuit.to_gate") method as appropriate. The results can be given directly to [`QuantumCircuit.append()`](qiskit.circuit.QuantumCircuit#append "qiskit.circuit.QuantumCircuit.append") on the larger circuit. These methods will create base [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") or [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") instances whose [`definition`](qiskit.circuit.Instruction#definition "qiskit.circuit.Instruction.definition") attribute is the circuit as supplied, meaning it will automatically be accessible to the transpiler, and to other Qiskit functions that attempt to decompose circuits. + +Note that standalone instructions and gates should act only on qubits and clbits; instructions that need to use complex control-flow will need to be inlined onto the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") using [`compose()`](qiskit.circuit.QuantumCircuit#compose "qiskit.circuit.QuantumCircuit.compose"). + +### Creating instruction subclasses + +The base classes [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"), [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") and [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") are all designed to be safe to subclass, and have hook points for subclasses to implement. If your custom gate is parameterless and stateless, you may also want to derive from the corresponding singleton class in [`qiskit.circuit.singleton`](circuit_singleton#module-qiskit.circuit.singleton "qiskit.circuit.singleton"), such as `SingletonGate`. You should consult the documentation in [`qiskit.circuit.singleton`](circuit_singleton#module-qiskit.circuit.singleton "qiskit.circuit.singleton") for additional methods and hook points for the singleton machinery. -**qiskit.circuit.CASE\_DEFAULT** +Subclasses should typically define a default constructor that calls the :class\`super\` constructor with the correct arguments for your instruction. It is permissible to have extra state in the class, but your subclasses will most reliably integrate with the rest of the Qiskit machinery if you depend only on your [`Instruction.params`](qiskit.circuit.Instruction#params "qiskit.circuit.Instruction.params"), and these parameters are purely gate angles. -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: +Subclasses of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") (or one of its subclasses) should implement the private [`Instruction._define()`](#qiskit.circuit.Instruction._define "qiskit.circuit.Instruction._define") method, which lazily populates the hidden `_definition` cache that backs the public [`definition`](qiskit.circuit.Instruction#definition "qiskit.circuit.Instruction.definition") method. + +#### \_define + + + Populate the cached `_definition` field of this [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"). + + Subclasses should implement this method to provide lazy construction of their public [`definition`](qiskit.circuit.Instruction#definition "qiskit.circuit.Instruction.definition") attribute. A subclass can use its [`params`](qiskit.circuit.Instruction#params "qiskit.circuit.Instruction.params") at the time of the call. The method should populate `_definition` with a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") and not return a value. + + +In subclasses of [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate"), the [`_define()`](#qiskit.circuit.Instruction._define "qiskit.circuit.Instruction._define") method should implement the decomposition only for the all-ones control state. The [`ControlledGate.definition`](qiskit.circuit.Instruction#definition "qiskit.circuit.Instruction.definition") machinery will modify this to handle the actual control state. + +If the subclass is using the singleton machinery, beware that [`_define()`](#qiskit.circuit.Instruction._define "qiskit.circuit.Instruction._define") will be called eagerly immediately after the class-body statement has been executed, in order to produce the definition object for the canonical singleton object. This means that your definition must only use gates that are already defined; if you are writing a library with many singleton gates, you will have to order your files and imports to ensure that this is possible. + +Subclasses of [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") will also likely wish to override [the Numpy array-protocol instance method](https://numpy.org/devdocs/user/basics.interoperability.html#the-array-method), `__array__`. This is used by [`Gate.to_matrix()`](qiskit.circuit.Gate#to_matrix "qiskit.circuit.Gate.to_matrix"), and has the signature: + +#### array\_\_ + + + Return a Numpy array representing the gate. This can use the gate’s `params` field, and may assume that these are numeric values (assuming the subclass expects that) and not [compile-time parameters](#circuit-compile-time-parameters). + + For greatest efficiency, the returned array should default to a dtype of [`complex`](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)"). + + +If your custom subclass has natural representations of its controlled or inverse forms, you may also wish to override the [`inverse()`](qiskit.circuit.Instruction#inverse "qiskit.circuit.Instruction.inverse") and [`control()`](qiskit.circuit.Gate#control "qiskit.circuit.Gate.control") methods. + +As an example of defining a custom $R_{xz}$ gate; that is, a single-angle rotation about the $XZ$ axis. This is essentially `RZXGate`, if the qubits were the other way around, so we will write our definition in terms of that. We are parametric, so cannot be a singleton, but we are unitary, so should be a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"): ```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) +import math +import numpy as np +from qiskit.circuit import Gate, QuantumCircuit + +class RXZGate(Gate): + def __init__(self, theta): + # Initialize with our name, number of qubits and parameters. + super().__init__("rxz", 2, [theta]) + + def _define(self): + # Our base definition is an RZXGate, applied "backwards". + defn = QuantumCircuit(2) + defn.rzx(1, 0) + self._definition = defn + + def inverse(self, annotated = False): + # We have an efficient representation of our inverse, + # so we'll override this method. + return RXZGate(-self.params[0]) + + def power(self, exponent: float): + # Also we have an efficient representation of power. + return RXZGate(exponent * self.params[0]) + + def __array__(self, dtype=None, copy=None): + if copy is False: + raise ValueError("unable to avoid copy while creating an array as requested") + cos = math.cos(0.5 * self.params[0]) + isin = 1j * math.sin(0.5 * self.params[0]) + return np.array([ + [cos, -isin, 0, 0], + [-isin, cos, 0, 0], + [0, 0, cos, isin], + [0, 0, isin, cos], + ], dtype=dtype) ``` -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: +In this example, we defined a base definition in terms of `RZXGate`, but to enable faster decompositions to a range of bases, we might want to add some more equivalences to [`SessionEquivalenceLibrary`](#qiskit.circuit.SessionEquivalenceLibrary "qiskit.circuit.SessionEquivalenceLibrary"). Note that the [`BasisTranslator`](qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator") translation search will search through all possible equivalences at all possible depths, so providing an equivalence in terms of (say) [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate") will automatically make decompositions in terms of [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate") available as well. + +Let us add an equivalence in terms of $H$, $CX$ and $R_z$ for an arbitrary symbolic parameter: ```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) +from qiskit.circuit import SessionEquivalenceLibrary, Parameter + +theta = Parameter("theta") + +equiv = QuantumCircuit(2) +equiv.h(0) +equiv.cx(1, 0) +equiv.rz(theta, 0) +equiv.cx(1, 0) +equiv.h(0) + +SessionEquivalenceLibrary.add_equivalence(RZXGate(theta), equiv) ``` -### Parametric Quantum Circuits +After this, for the duration of the Python interpreter session, translators like [`BasisTranslator`](qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator") will find our new definition in their search. -| | | -| ------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------- | -| [`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. | + + +## Working with circuit-level objects + + + +### Converting abstract circuits to physical circuits -### Gate Commutation +An abstract [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") cannot reliably be run on hardware. You might be able to use some of the high-level simulators linked to in [Simulating circuits](#circuit-simulation) to produce quick results for small scale circuits, but to run utility-scale circuits, you will need to use real hardware, which involves compiling to a physical circuit. -| | | -| ----------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------- | -| [`CommutationChecker`](qiskit.circuit.CommutationChecker "qiskit.circuit.CommutationChecker")(\[...]) | This code is essentially copy-pasted from commutative\_analysis.py. | +The high-level function to do this is [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile"); it takes in an abstract circuit and a hardware `backend` or `target`, and returns a physical circuit. To get more access and control over the stages of the passes that will be run, use [`generate_preset_pass_manager()`](transpiler_preset#qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager "qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager") to build a [`StagedPassManager`](qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager") first, which you can then modify. -### Random Circuits +The full transpilation and compilation machinery is described in detail in the [`qiskit.transpiler`](transpiler#module-qiskit.transpiler "qiskit.transpiler") module documentation, and detail on all the passes built into Qiskit is available in [`qiskit.transpiler.passes`](transpiler_passes#module-qiskit.transpiler.passes "qiskit.transpiler.passes"). + + + +### Simulating circuits + +While not part of the [`qiskit.circuit`](#module-qiskit.circuit "qiskit.circuit") interface, one of the most common needs is to get quick simulation results for [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") objects. This section provides a quick jumping-off point to other places in the documentation to find the relevant information. + +For unitary circuits, you can simulate the effects on the $\lvert0\dotsm0\rangle$ state by passing the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") directly to the [`Statevector`](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") default constructor. You can similar get a unitary matrix representing the circuit as an operator by passing it to the [`Operator`](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") default constructor. If you have a physical circuit, you may want to instead pass it to [`Operator.from_circuit()`](qiskit.quantum_info.Operator#from_circuit "qiskit.quantum_info.Operator.from_circuit") method to apply transformations from the [`QuantumCircuit.layout`](qiskit.circuit.QuantumCircuit#layout "qiskit.circuit.QuantumCircuit.layout") to map it back to the “abstract” qubit space. + +For a more backend-like simulation experience, there are simulator-backed implementations of all the Qiskit hardware interfaces. In particular, you might be interested in: + +* [`BasicProvider`](qiskit.providers.basic_provider.BasicProvider "qiskit.providers.basic_provider.BasicProvider") and the raw backends it can return to you. +* `StatevectorSimulator` for a backend-like wrapper around [`Statevector`](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") +* The [`qiskit_aer`](https://qiskit.github.io/qiskit-aer/apidocs/aer_provider.html#module-qiskit_aer "(in Qiskit Aer v0.14.1)") for full, high-performance simulation capabilities. +* [`StatevectorSampler`](qiskit.primitives.StatevectorSampler "qiskit.primitives.StatevectorSampler") and [`StatevectorEstimator`](qiskit.primitives.StatevectorEstimator "qiskit.primitives.StatevectorEstimator") for simulator-backed reference implementations of the [Qiskit Primitives](primitives#qiskit-primitives). + +### Defining equivalence relationships + +A common task in mapping abstract circuits to physical hardware and optimizing the result is to find equivalence relations that map a gate to a different basis set. Qiskit stores this information in a database class called [`EquivalenceLibrary`](qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary"). + +| | | +| ---------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------ | +| [`EquivalenceLibrary`](qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary")(\*\[, base]) | A library providing a one-way mapping of Gates to their equivalent implementations as QuantumCircuits. | + +Qiskit ships with a large set of predefined equivalence relationships for all of its standard gates. This base library is called [`StandardEquivalenceLibrary`](#qiskit.circuit.StandardEquivalenceLibrary "qiskit.circuit.StandardEquivalenceLibrary"), and should be treated as immutable. + +**qiskit.circuit.StandardEquivalenceLibrary** + +A [`EquivalenceLibrary`](qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary") that stores of all Qiskit’s built-in standard gate relationships. You should not mutate this, but instead either create your own [`EquivalenceLibrary`](qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary") using this one as its `base`, or modify the global-state [`SessionEquivalenceLibrary`](#qiskit.circuit.SessionEquivalenceLibrary "qiskit.circuit.SessionEquivalenceLibrary"). + +Qiskit also defines a shared global-state object, [`SessionEquivalenceLibrary`](#qiskit.circuit.SessionEquivalenceLibrary "qiskit.circuit.SessionEquivalenceLibrary"), which is the default equivalences used by various places in Qiskit, most notably the [`BasisTranslator`](qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator") transpiler pass. You should feel free to add your own equivalences to this using its [`add_equivalence()`](qiskit.circuit.EquivalenceLibrary#add_equivalence "qiskit.circuit.EquivalenceLibrary.add_equivalence") method, and they will be automatically picked up by default instances of the [`BasisTranslator`](qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator"). + +**qiskit.circuit.SessionEquivalenceLibrary** + +The default instance of [`EquivalenceLibrary`](qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary"), which will be used by most Qiskit objects if no library is manually specified. You can feel free to add equivalences to this using [`add_equivalence()`](qiskit.circuit.EquivalenceLibrary#add_equivalence "qiskit.circuit.EquivalenceLibrary.add_equivalence"). It inherits all the built-in rules of [`StandardEquivalenceLibrary`](#qiskit.circuit.StandardEquivalenceLibrary "qiskit.circuit.StandardEquivalenceLibrary"). + +### Generating random circuits #### random\_circuit - + 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: @@ -314,7 +827,7 @@ with qc.switch(cr) as case: circ.draw(output='mpl') ``` - ![../\_images/circuit-5.png](/images/api/qiskit/circuit-5.png) + ![../\_images/circuit-2.png](/images/api/qiskit/circuit-2.png) **Parameters** @@ -339,15 +852,166 @@ with qc.switch(cr) as case: [**CircuitError**](#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – when invalid options given -### Exceptions +## 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 +### CircuitError - + Base class for errors raised while processing a circuit. Set the error message. + + +## Circuit conventions + +When constructing circuits out of abstract objects and more concrete matrices, there are several possible conventions around bit-labelling, bit-ordering, and how the abstract tensor product is realized in concrete matrix algebra. + +Qiskit’s conventions are: + +* in bitstring representations, bits are labelled with the right-most bit in the string called $0$ and the left-most bit in the string of $n$ bits called $n - 1$. +* when using integers as bit-specifier indices in circuit-construction functions, the integer is treated as an index into [`QuantumCircuit.qubits`](qiskit.circuit.QuantumCircuit#qubits "qiskit.circuit.QuantumCircuit.qubits") (or [`clbits`](qiskit.circuit.QuantumCircuit#clbits "qiskit.circuit.QuantumCircuit.clbits")). +* when drawing circuits, we put the lowest-index bits on top. +* in statevector representations, we realize the abstract tensor product as the Kronecker product, and order the arguments to this such that the amplitude of computational-basis state $\lvert x\rangle$, where $x$ is the bitstring interpreted as an integer, is at location `statevector[x]`. +* when controlling a gate, the control qubit(s) is placed first in the argument list, *e.g.* in the call `qc.cx(0, 1)`, qubit 0 will be the control and qubit 1 will be the target. Similarly, in the manual call `qc.append(CXGate(), [0, 1])`, qubit 0 will be the control and qubit 1 will be the target. + +Let us illustrate these conventions with some examples. + +### Bit labelling + +Take the circuit: + +```python +from qiskit import QuantumCircuit + +qc = QuantumCircuit(5, 5) +qc.x(0) +qc.x(1) +qc.x(4) +qc.measure(range(5), range(5)) +``` + +This flips the states of qubits 0, 1 and 4 from $\lvert0\rangle$ to $\lvert1\rangle$, then measures all qubits $n$ into the corresponding clbit $n$ using the computational ($Z$) basis. If simulated noiselessly, the bitstring output from this circuit will be $10011$ every time; qubits 0, 1, and 4 are flipped, and the “one” values in the bitstring are in the zeroth, first and fourth digits *from the right*. + +In Qiskit, we would write the qubit state immediately before the measurement in ket-notation shorthand as $\lvert10011\rangle$. Note that the ket label matches the classical bitstring, and has the numeric binary value of 19. + +If we draw this circuit, we will see that Qiskit places the zeroth qubit on the top of the circuit drawing: + +```python +qc.draw("mpl") +``` + +![../\_images/circuit-4.png](/images/api/qiskit/circuit-4.png) + +### Matrix representations + +Statevectors are defined in the convention that for a two-level system, the relationship between abstract representation and matrix representation is such that + +$$ +\alpha\lvert0\rangle + \beta\lvert1\rangle + \leftrightarrow \begin{pmatrix} \alpha \\ \beta \end{pmatrix} +$$ + +where $\alpha$ and $\beta$ are complex numbers. We store the statevector as a 1D Numpy [`ndarray`](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") with data `sv = [alpha, beta]`, *i.e.* `sv[0] == alpha` and `sv[1] == beta`; note that the indices into the statevector match the ket labels. + +We construct [the tensor product of two qubit states](https://en.wikipedia.org/wiki/Tensor_product) in matrix algebra using [the Kronecker product](https://en.wikipedia.org/wiki/Kronecker_product), with qubit 0 on the right and qubit 1 on the left, such that the $Z$ basis state $\lvert x\rangle$ (where $x$ is the integer interpretation of the bitstring) has its non-zero term in the statevector `sv` at `sv[x]`: + +```python +import numpy +from qiskit import QuantumCircuit +from qiskit.quantum_info import Statevector + +state_0 = [1, 0] # defined representation of |0> +state_1 = [0, 1] # defined representation of |1> + +# Circuit that creates basis state |10011>, where +# binary 10011 has the decimal value 19. +qc = QuantumCircuit(5) +qc.x(0) +qc.x(1) +qc.x(4) +qiskit_sv = Statevector(qc) + +# List index 'n' corresponds to qubit 'n'. +individual_states = [ + state_1, + state_1, + state_0, + state_0, + state_1, +] +# Start from a scalar. +manual_sv = [1] +for qubit_state in individual_states: + # Each new qubit goes "on the left". + manual_sv = numpy.kron(qubit_state, manual_sv) + +# Now `qiskit_sv` and `manual_sv` are the same, and: +assert manual_sv[19] == 1 +assert qiskit_sv[19] == 1 +``` + +This feeds through to the matrix representation of operators, and joins with the conventions on bit orders for controlled operators. For example, the matrix form of [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate") is: + +```python +import numpy +from qiskit.circuit.library import CXGate + +numpy.array(CXGate()) +``` + +$$ +\operatorname{array}(CX) = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 0 & 0 & 1 \\ + 0 & 0 & 1 & 0 \\ + 0 & 1 & 0 & 0 + \end{pmatrix} +$$ + +This might be different to other matrix representations you have seen for $CX$, but recall that the choice of matrix representation is conventional, and this form matches Qiskit’s conventions of *control qubits come first* and *the tensor product is represented such that there is a correspondence between the index of the “one amplitude” and the bitstring value of a state*. + +In the case of multiple controls for a gate, such as for [`CCXGate`](qiskit.circuit.library.CCXGate "qiskit.circuit.library.CCXGate"), the `ctrl_state` argument is interpreted as the bitstring value of the control qubits, using the same zero-based labelling conventions. For example, given that the default `ctrl_state` is the all-ones bitstring, we can see that the matrix form of [`CCXGate`](qiskit.circuit.library.CCXGate "qiskit.circuit.library.CCXGate") with `ctrl_state = 1` is the same as if we took the all-ones control-state [`CCXGate`](qiskit.circuit.library.CCXGate "qiskit.circuit.library.CCXGate"), but flipped the value of the higher indexed control qubit on entry and exist to the gate: + +```python +from qiskit import QuantumCircuit +from qiskit.quantum_info import Operator + +# Build the natural representation of `CCX` with the +# control qubits being `[0, 1]`, relative to the +# bitstring state "01", such that qubit 0 must be in |1> +# and qubit 1 must be in |0>. The target qubit is 2. +ccx_natural = QuantumCircuit(3) +ccx_natural.ccx(0, 1, 2, ctrl_state=1) + +# Build the same circuit in terms of the all-ones CCX. +# Note that we flip _qubit 1_, because that's the one +# that differs from the all-ones state. +ccx_relative = QuantumCircuit(3) +ccx_relative.x(1) +ccx_relative.ccx(0, 1, 2) +ccx_relative.x(1) + +assert Operator(ccx_relative) == Operator(ccx_natural) +``` + +In both these cases, the matrix form of [`CCXGate`](qiskit.circuit.library.CCXGate "qiskit.circuit.library.CCXGate") in `ctrl_state = 1` is: + +$$ +\operatorname{array}\bigl(CCX(\text{ctrl\_state}=1)\bigr) = + \begin{pmatrix} + 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 & 0 & 0 \\ + 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 \\ + 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 + \end{pmatrix} +$$ + diff --git a/docs/api/qiskit/circuit_classical.mdx b/docs/api/qiskit/circuit_classical.mdx index 8bb7ae3dc49..029a956f583 100644 --- a/docs/api/qiskit/circuit_classical.mdx +++ b/docs/api/qiskit/circuit_classical.mdx @@ -18,7 +18,7 @@ python_api_name: qiskit.circuit.classical `qiskit.circuit.classical` -This module contains an exploratory representation of runtime operations on classical values during circuit execution. +This module contains an exploratory representation of real-time 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")). @@ -50,7 +50,7 @@ The expression system is based on tree representation. All nodes in the tree are #### Expr - + 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. @@ -60,21 +60,45 @@ The expression system is based on tree representation. All nodes in the tree are 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. +The base for dynamic variables is the [`Var`](#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var"), which can be either an arbitrarily typed real-time variable, or a wrapper around a [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") or [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister"). #### Var - + A classical variable. + These variables take two forms: a new-style variable that owns its storage location and has an associated name; and an old-style variable that wraps a [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") or [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") instance that is owned by some containing circuit. In general, construction of variables for use in programs should use [`Var.new()`](#qiskit.circuit.classical.expr.Var.new "qiskit.circuit.classical.expr.Var.new") or [`QuantumCircuit.add_var()`](qiskit.circuit.QuantumCircuit#add_var "qiskit.circuit.QuantumCircuit.add_var"). + Variables are immutable after construction, so they can be used as dictionary keys. + + ##### name + + + The name of the variable. This is required to exist if the backing [`var`](#qiskit.circuit.classical.expr.Var.var "qiskit.circuit.classical.expr.Var.var") attribute is a [`UUID`](https://docs.python.org/3/library/uuid.html#uuid.UUID "(in Python v3.12)"), i.e. if it is a new-style variable, and must be `None` if it is an old-style variable. + + + ##### new + + + Generate a new named variable that owns its own backing storage. + + **Return type** + + [*Self*](https://docs.python.org/3/library/typing.html#typing.Self "(in Python v3.12)") + + + ##### var + + + A reference to the backing data storage of the [`Var`](#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instance. When lifting old-style [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") or [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") instances into a [`Var`](#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var"), this is exactly the [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") or [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister"). If the variable is a new-style classical variable (one that owns its own storage separate to the old [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit")/[`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") model), this field will be a [`UUID`](https://docs.python.org/3/library/uuid.html#uuid.UUID "(in Python v3.12)") to uniquely identify it. + -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. +Similarly, literals used in expressions (such as integers) should be lifted to [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes with associated types. #### Value - + A single scalar value. @@ -82,7 +106,7 @@ The operations traditionally associated with pre-, post- or infix operators in p #### Unary - + A unary expression. **Parameters** @@ -93,7 +117,7 @@ The operations traditionally associated with pre-, post- or infix operators in p ##### Op - + 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. @@ -116,7 +140,7 @@ The operations traditionally associated with pre-, post- or infix operators in p #### Binary - + A binary expression. **Parameters** @@ -128,7 +152,7 @@ The operations traditionally associated with pre-, post- or infix operators in p ##### Op - + 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. @@ -137,6 +161,8 @@ The operations traditionally associated with pre-, post- or infix operators in p 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. + The bitshift operations [`SHIFT_LEFT`](#qiskit.circuit.classical.expr.Binary.Op.SHIFT_LEFT "qiskit.circuit.classical.expr.Binary.Op.SHIFT_LEFT") and [`SHIFT_RIGHT`](#qiskit.circuit.classical.expr.Binary.Op.SHIFT_RIGHT "qiskit.circuit.classical.expr.Binary.Op.SHIFT_RIGHT") can take bit-like container types (e.g. unsigned integers) as the left operand, and any integer type as the right-hand operand. In all cases, the output bit width is the same as the input, and zeros fill in the “exposed” spaces. + ###### BIT\_AND @@ -202,16 +228,42 @@ The operations traditionally associated with pre-, post- or infix operators in p Numeric greater than or equal to. `lhs >= rhs`. + + ###### SHIFT\_LEFT + + + Zero-padding bitshift to the left. `lhs << rhs`. + + + ###### SHIFT\_RIGHT + + + Zero-padding bitshift to the right. `lhs >> rhs`. + +Bit-like types (unsigned integers) can be indexed by integer types, represented by [`Index`](#qiskit.circuit.classical.expr.Index "qiskit.circuit.classical.expr.Index"). The result is a single bit. The resulting expression has an associated memory location (and so can be used as an lvalue for [`Store`](circuit#qiskit.circuit.Store "qiskit.circuit.Store"), etc) if the target is also an lvalue. + +#### Index + + + An indexing expression. + + **Parameters** + + * **target** ([*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")) – The object being indexed. + * **index** ([*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")) – The expression doing the indexing. + * **type** ([*Type*](#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.types.Type")) – The resolved type of the result. + + 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. #### Cast - + A cast from one type to another, implied by the use of an expression in a different context. @@ -225,7 +277,7 @@ The functions and methods described in this section are a more user-friendly way #### lift - + 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. @@ -259,11 +311,13 @@ The functions and methods described in this section are a more user-friendly way [Expr](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") +Typically you should create memory-owning [`Var`](#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instances by using the [`QuantumCircuit.add_var()`](qiskit.circuit.QuantumCircuit#add_var "qiskit.circuit.QuantumCircuit.add_var") method to declare them in some circuit context, since a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") will not accept an [`Expr`](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") that contains variables that are not already declared in it, since it needs to know how to allocate the storage and how the variable will be initialized. However, should you want to do this manually, you should use the low-level [`Var.new()`](#qiskit.circuit.classical.expr.Var.new "qiskit.circuit.classical.expr.Var.new") call to safely generate a named variable for usage. + 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 - + Create an explicit cast from the given value to the given type. **Examples** @@ -286,12 +340,12 @@ There are helper constructor functions for each of the unary operations. #### bit\_not - + 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"): + Bitwise negation of a [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister"): ```python >>> from qiskit.circuit import ClassicalRegister @@ -307,12 +361,12 @@ There are helper constructor functions for each of the unary operations. #### logic\_not - + 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"): + Logical negation of a [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister"): ```python >>> from qiskit.circuit import ClassicalRegister @@ -330,7 +384,7 @@ Similarly, the binary operations and relations have helper functions defined. #### bit\_and - + 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** @@ -351,7 +405,7 @@ Similarly, the binary operations and relations have helper functions defined. #### bit\_or - + 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** @@ -372,7 +426,7 @@ Similarly, the binary operations and relations have helper functions defined. #### bit\_xor - + 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** @@ -393,7 +447,7 @@ Similarly, the binary operations and relations have helper functions defined. #### logic\_and - + 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** @@ -414,7 +468,7 @@ Similarly, the binary operations and relations have helper functions defined. #### logic\_or - + 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** @@ -435,7 +489,7 @@ Similarly, the binary operations and relations have helper functions defined. #### equal - + 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** @@ -456,7 +510,7 @@ Similarly, the binary operations and relations have helper functions defined. #### not\_equal - + 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** @@ -477,7 +531,7 @@ Similarly, the binary operations and relations have helper functions defined. #### less - + 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** @@ -498,7 +552,7 @@ Similarly, the binary operations and relations have helper functions defined. #### less\_equal - + 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** @@ -519,7 +573,7 @@ Similarly, the binary operations and relations have helper functions defined. #### greater - + 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** @@ -540,7 +594,7 @@ Similarly, the binary operations and relations have helper functions defined. #### greater\_equal - + 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** @@ -559,11 +613,89 @@ Similarly, the binary operations and relations have helper functions defined. [*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. +#### shift\_left + + + Create a ‘bitshift left’ expression node from the given two values, resolving any implicit casts and lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. + + If `type` is given, the `left` operand will be coerced to it (if possible). + + **Examples** + + Shift the value of a standalone variable left by some amount: + + ```python + >>> from qiskit.circuit.classical import expr, types + >>> a = expr.Var.new("a", types.Uint(8)) + >>> expr.shift_left(a, 4) + Binary(Binary.Op.SHIFT_LEFT, Var(, Uint(8), name='a'), Value(4, Uint(3)), Uint(8)) + ``` + + Shift an integer literal by a variable amount, coercing the type of the literal: + + ```python + >>> expr.shift_left(3, a, types.Uint(16)) + Binary(Binary.Op.SHIFT_LEFT, Value(3, Uint(16)), Var(, Uint(8), name='a'), Uint(16)) + ``` + + **Return type** + + [Expr](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") + + +#### shift\_right + + + Create a ‘bitshift right’ expression node from the given values, resolving any implicit casts and lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. + + If `type` is given, the `left` operand will be coerced to it (if possible). + + **Examples** + + Shift the value of a classical register right by some amount: + + ```python + >>> from qiskit.circuit import ClassicalRegister + >>> from qiskit.circuit.classical import expr + >>> expr.shift_right(ClassicalRegister(8, "a"), 4) + Binary(Binary.Op.SHIFT_RIGHT, Var(ClassicalRegister(8, "a"), Uint(8)), Value(4, Uint(3)), Uint(8)) + ``` + + **Return type** + + [Expr](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") + + +You can index into unsigned integers and bit-likes using another unsigned integer of any width. This includes in storing operations, if the target of the index is writeable. + +#### index + + + Index into the `target` with the given integer `index`, lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. + + This can be used as the target of a [`Store`](circuit#qiskit.circuit.Store "qiskit.circuit.Store"), if the `target` is itself an lvalue. + + **Examples** + + Index into a classical register with a literal: + + ```python + >>> from qiskit.circuit import ClassicalRegister + >>> from qiskit.circuit.classical import expr + >>> expr.index(ClassicalRegister(8, "a"), 3) + Index(Var(ClassicalRegister(8, "a"), Uint(8)), Value(3, Uint(2)), Bool()) + ``` + + **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`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") or [`ClassicalRegister`](circuit#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 - + Lift a legacy two-tuple equality condition into a new-style [`Expr`](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr"). **Examples** @@ -592,12 +724,12 @@ A typical consumer of the expression tree wants to recursively walk through the #### ExprVisitor - + 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 - + **Return type** *\_T\_co* @@ -605,7 +737,7 @@ A typical consumer of the expression tree wants to recursively walk through the ##### visit\_cast - + **Return type** *\_T\_co* @@ -613,7 +745,15 @@ A typical consumer of the expression tree wants to recursively walk through the ##### visit\_generic - + + **Return type** + + *\_T\_co* + + + ##### visit\_index + + **Return type** *\_T\_co* @@ -621,7 +761,7 @@ A typical consumer of the expression tree wants to recursively walk through the ##### visit\_unary - + **Return type** *\_T\_co* @@ -629,7 +769,7 @@ A typical consumer of the expression tree wants to recursively walk through the ##### visit\_value - + **Return type** *\_T\_co* @@ -637,7 +777,7 @@ A typical consumer of the expression tree wants to recursively walk through the ##### visit\_var - + **Return type** *\_T\_co* @@ -650,12 +790,12 @@ For the convenience of simple visitors that only need to inspect the variables i #### iter\_vars - + 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: + Print out the name of each [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") encountered: ```python from qiskit.circuit import ClassicalRegister @@ -678,10 +818,10 @@ Two expressions can be compared for direct structural equality by using the buil #### structurally\_equivalent - + 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). + In other words, are these two expressions the exact same trees, except we compare the [`Var.var`](#qiskit.circuit.classical.expr.Var.var "qiskit.circuit.classical.expr.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. @@ -689,7 +829,7 @@ Two expressions can be compared for direct structural equality by using the buil * **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. + * **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`](#qiskit.circuit.classical.expr.Var.var "qiskit.circuit.classical.expr.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** @@ -698,7 +838,7 @@ Two expressions can be compared for direct structural equality by using the buil **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: + Comparing two expressions for structural equivalence, with no remapping of the variables. These are different because the different [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") instances compare differently: ```python >>> from qiskit.circuit import Clbit @@ -721,6 +861,52 @@ Two expressions can be compared for direct structural equality by using the buil ``` +Some expressions have associated memory locations, and others may be purely temporary. You can use [`is_lvalue()`](#qiskit.circuit.classical.expr.is_lvalue "qiskit.circuit.classical.expr.is_lvalue") to determine whether an expression has an associated memory location. + +#### is\_lvalue + + + Return whether this expression can be used in l-value positions, that is, whether it has a well-defined location in memory, such as one that might be writeable. + + Being an l-value is a necessary but not sufficient for this location to be writeable; it is permissible that a larger object containing this memory location may not allow writing from the scope that attempts to write to it. This would be an access property of the containing program, however, and not an inherent property of the expression system. + + **Examples** + + Literal values are never l-values; there’s no memory location associated with (for example) the constant `1`: + + ```python + >>> from qiskit.circuit.classical import expr + >>> expr.is_lvalue(expr.lift(2)) + False + ``` + + [`Var`](#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var") nodes are always l-values, because they always have some associated memory location: + + ```python + >>> from qiskit.circuit.classical import types + >>> from qiskit.circuit import Clbit + >>> expr.is_lvalue(expr.Var.new("a", types.Bool())) + True + >>> expr.is_lvalue(expr.lift(Clbit())) + True + ``` + + Currently there are no unary or binary operations on variables that can produce an l-value expression, but it is likely in the future that some sort of “indexing” operation will be added, which could produce l-values: + + ```python + >>> a = expr.Var.new("a", types.Uint(8)) + >>> b = expr.Var.new("b", types.Uint(8)) + >>> expr.is_lvalue(a) and expr.is_lvalue(b) + True + >>> expr.is_lvalue(expr.bit_and(a, b)) + False + ``` + + **Return type** + + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + @@ -741,7 +927,7 @@ All types inherit from an abstract base class: #### Type - + 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. @@ -749,17 +935,17 @@ All types inherit from an abstract base class: 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). +The two different types available are for Booleans (corresponding to [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") and the literals `True` and `False`), and unsigned integers (corresponding to [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") and Python integers). #### Bool - + The Boolean type. This has exactly two values: `True` and `False`. #### Uint - + An unsigned integer of fixed bit width. @@ -767,17 +953,17 @@ Note that [`Uint`](#qiskit.circuit.classical.types.Uint "qiskit.circuit.classica ### Working with types -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. +There are some additional functions on these types documented in the subsequent sections. 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. -#### Partial ordering of types +### Partial ordering of types 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 +#### order - + Get the ordering relationship between the two types as an enumeration value. **Examples** @@ -804,9 +990,9 @@ The low-level interface to querying the subtyping relationship is the [`order()` 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. -##### Ordering +#### Ordering - + 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. @@ -814,9 +1000,9 @@ The return value is an enumeration [`Ordering`](#qiskit.circuit.classical.types. 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 +#### is\_subtype - + 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** @@ -843,9 +1029,9 @@ Some helper methods are then defined in terms of this low-level [`order()`](#qis [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") -##### is\_supertype +#### is\_supertype - + 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** @@ -872,9 +1058,9 @@ Some helper methods are then defined in terms of this low-level [`order()`](#qis [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") -##### greater +#### greater - + 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** @@ -900,13 +1086,13 @@ Some helper methods are then defined in terms of this low-level [`order()`](#qis ``` -#### Casting between types +### Casting between types It is common to need to cast values of one type to another type. The casting rules for this are embedded into the [`types`](https://docs.python.org/3/library/types.html#module-types "(in Python v3.12)") module. You can query the casting kinds using [`cast_kind()`](#qiskit.circuit.classical.types.cast_kind "qiskit.circuit.classical.types.cast_kind"): -##### cast\_kind +#### cast\_kind - + Determine the sort of cast that is required to move from the left type to the right type. **Examples** @@ -930,9 +1116,9 @@ It is common to need to cast values of one type to another type. The casting rul The return values from this function are an enumeration explaining the types of cast that are allowed from the left type to the right type. -##### CastKind +#### CastKind - + A return value indicating the type of cast that can occur from one type to another. diff --git a/docs/api/qiskit/circuit_library.mdx b/docs/api/qiskit/circuit_library.mdx index 58a7137f92e..20efe6e4147 100644 --- a/docs/api/qiskit/circuit_library.mdx +++ b/docs/api/qiskit/circuit_library.mdx @@ -122,18 +122,14 @@ print(gate.control(1).to_matrix()) # CX (controlled X) gate 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. | +* [`qiskit.circuit.Barrier`](circuit#qiskit.circuit.Barrier "qiskit.circuit.Barrier") ## Standard Operations Operations are non-reversible changes in the quantum state of the circuit. -| | | -| --------------------------------------------------------------------------------------------------------- | ----------------------------------------------- | -| [`Measure`](qiskit.circuit.library.Measure "qiskit.circuit.library.Measure")(\*args\[, \_force\_mutable]) | Quantum measurement in the computational basis. | -| [`Reset`](qiskit.circuit.library.Reset "qiskit.circuit.library.Reset")(\*args\[, \_force\_mutable]) | Qubit reset. | +* [`qiskit.circuit.Measure`](circuit#qiskit.circuit.Measure "qiskit.circuit.Measure") +* [`qiskit.circuit.Reset`](circuit#qiskit.circuit.Reset "qiskit.circuit.Reset") ## Generalized Gates @@ -176,7 +172,7 @@ print(diagonal.num_qubits) | [`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. | +| [`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. | @@ -326,7 +322,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_2a\_1 - + **Returns** template as a quantum circuit. @@ -338,7 +334,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_2a\_2 - + **Returns** template as a quantum circuit. @@ -350,7 +346,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_2a\_3 - + **Returns** template as a quantum circuit. @@ -362,7 +358,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_4a\_1 - + **Returns** template as a quantum circuit. @@ -374,7 +370,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_4a\_2 - + **Returns** template as a quantum circuit. @@ -386,7 +382,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_4a\_3 - + **Returns** template as a quantum circuit. @@ -398,7 +394,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_4b\_1 - + **Returns** template as a quantum circuit. @@ -410,7 +406,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_4b\_2 - + **Returns** template as a quantum circuit. @@ -422,7 +418,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_5a\_1 - + **Returns** template as a quantum circuit. @@ -434,7 +430,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_5a\_2 - + **Returns** template as a quantum circuit. @@ -446,7 +442,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_5a\_3 - + **Returns** template as a quantum circuit. @@ -458,7 +454,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_5a\_4 - + **Returns** template as a quantum circuit. @@ -470,7 +466,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_6a\_1 - + **Returns** template as a quantum circuit. @@ -482,7 +478,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_6a\_2 - + **Returns** template as a quantum circuit. @@ -494,7 +490,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_6a\_3 - + **Returns** template as a quantum circuit. @@ -506,7 +502,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_6a\_4 - + **Returns** template as a quantum circuit. @@ -518,7 +514,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_6b\_1 - + **Returns** template as a quantum circuit. @@ -530,7 +526,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_6b\_2 - + **Returns** template as a quantum circuit. @@ -542,7 +538,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_6c\_1 - + **Returns** template as a quantum circuit. @@ -554,7 +550,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_7a\_1 - + **Returns** template as a quantum circuit. @@ -566,7 +562,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_7b\_1 - + **Returns** template as a quantum circuit. @@ -578,7 +574,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_7c\_1 - + **Returns** template as a quantum circuit. @@ -590,7 +586,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_7d\_1 - + **Returns** template as a quantum circuit. @@ -602,7 +598,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_7e\_1 - + **Returns** template as a quantum circuit. @@ -614,7 +610,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9a\_1 - + **Returns** template as a quantum circuit. @@ -626,7 +622,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_1 - + **Returns** template as a quantum circuit. @@ -638,7 +634,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_2 - + **Returns** template as a quantum circuit. @@ -650,7 +646,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_3 - + **Returns** template as a quantum circuit. @@ -662,7 +658,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_4 - + **Returns** template as a quantum circuit. @@ -674,7 +670,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_5 - + **Returns** template as a quantum circuit. @@ -686,7 +682,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_6 - + **Returns** template as a quantum circuit. @@ -698,7 +694,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_7 - + **Returns** template as a quantum circuit. @@ -710,7 +706,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_8 - + **Returns** template as a quantum circuit. @@ -722,7 +718,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_9 - + **Returns** template as a quantum circuit. @@ -734,7 +730,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_10 - + **Returns** template as a quantum circuit. @@ -746,7 +742,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_11 - + **Returns** template as a quantum circuit. @@ -758,7 +754,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_12 - + **Returns** template as a quantum circuit. @@ -770,7 +766,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_1 - + **Returns** template as a quantum circuit. @@ -782,7 +778,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_2 - + **Returns** template as a quantum circuit. @@ -794,7 +790,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_3 - + **Returns** template as a quantum circuit. @@ -806,7 +802,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_4 - + **Returns** template as a quantum circuit. @@ -818,7 +814,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_5 - + **Returns** template as a quantum circuit. @@ -830,7 +826,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_6 - + **Returns** template as a quantum circuit. @@ -842,7 +838,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_7 - + **Returns** template as a quantum circuit. @@ -854,7 +850,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_8 - + **Returns** template as a quantum circuit. @@ -866,7 +862,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_9 - + **Returns** template as a quantum circuit. @@ -878,7 +874,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_10 - + **Returns** template as a quantum circuit. @@ -894,7 +890,7 @@ Template circuits over Clifford gates. #### clifford\_2\_1 - + **Returns** template as a quantum circuit. @@ -906,7 +902,7 @@ Template circuits over Clifford gates. #### clifford\_2\_2 - + **Returns** template as a quantum circuit. @@ -918,7 +914,7 @@ Template circuits over Clifford gates. #### clifford\_2\_3 - + **Returns** template as a quantum circuit. @@ -930,7 +926,7 @@ Template circuits over Clifford gates. #### clifford\_2\_4 - + **Returns** template as a quantum circuit. @@ -942,7 +938,7 @@ Template circuits over Clifford gates. #### clifford\_3\_1 - + **Returns** template as a quantum circuit. @@ -954,7 +950,7 @@ Template circuits over Clifford gates. #### clifford\_4\_1 - + **Returns** template as a quantum circuit. @@ -966,7 +962,7 @@ Template circuits over Clifford gates. #### clifford\_4\_2 - + **Returns** template as a quantum circuit. @@ -978,7 +974,7 @@ Template circuits over Clifford gates. #### clifford\_4\_3 - + **Returns** template as a quantum circuit. @@ -990,7 +986,7 @@ Template circuits over Clifford gates. #### clifford\_4\_4 - + **Returns** template as a quantum circuit. @@ -1002,7 +998,7 @@ Template circuits over Clifford gates. #### clifford\_5\_1 - + **Returns** template as a quantum circuit. @@ -1014,7 +1010,7 @@ Template circuits over Clifford gates. #### clifford\_6\_1 - + **Returns** template as a quantum circuit. @@ -1026,7 +1022,7 @@ Template circuits over Clifford gates. #### clifford\_6\_2 - + **Returns** template as a quantum circuit. @@ -1038,7 +1034,7 @@ Template circuits over Clifford gates. #### clifford\_6\_3 - + **Returns** template as a quantum circuit. @@ -1050,7 +1046,7 @@ Template circuits over Clifford gates. #### clifford\_6\_4 - + **Returns** template as a quantum circuit. @@ -1062,7 +1058,7 @@ Template circuits over Clifford gates. #### clifford\_6\_5 - + **Returns** template as a quantum circuit. @@ -1074,7 +1070,7 @@ Template circuits over Clifford gates. #### clifford\_8\_1 - + **Returns** template as a quantum circuit. @@ -1086,7 +1082,7 @@ Template circuits over Clifford gates. #### clifford\_8\_2 - + **Returns** template as a quantum circuit. @@ -1098,7 +1094,7 @@ Template circuits over Clifford gates. #### clifford\_8\_3 - + **Returns** template as a quantum circuit. @@ -1114,37 +1110,37 @@ Template circuits with [`RZXGate`](qiskit.circuit.library.RZXGate "qiskit.circui #### rzx\_yz - + Template for CX - RYGate - CX. #### rzx\_xz - + Template for CX - RXGate - CX. #### rzx\_cy - + Template for CX - RYGate - CX. #### rzx\_zz1 - + Template for CX - RZGate - CX. #### rzx\_zz2 - + Template for CX - RZGate - CX. #### rzx\_zz3 - + Template for CX - RZGate - CX. diff --git a/docs/api/qiskit/circuit_singleton.mdx b/docs/api/qiskit/circuit_singleton.mdx index ee91fb85a10..aed0e118dbb 100644 --- a/docs/api/qiskit/circuit_singleton.mdx +++ b/docs/api/qiskit/circuit_singleton.mdx @@ -24,7 +24,7 @@ The machinery in this module is for defining subclasses of [`Instruction`](qiski * 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 same can be true for, for example, [`Measure`](circuit#qiskit.circuit.Measure "qiskit.circuit.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. @@ -46,17 +46,17 @@ The public classes correspond to the standard classes [`Instruction`](qiskit.cir ### SingletonInstruction - + 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. + 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`](circuit#qiskit.circuit.Measure "qiskit.circuit.Measure") which has an immutable definition and any instance of [`Measure`](circuit#qiskit.circuit.Measure "qiskit.circuit.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. ### SingletonGate - + 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. @@ -64,7 +64,7 @@ The public classes correspond to the standard classes [`Instruction`](qiskit.cir ### SingletonControlledGate - + 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. @@ -126,7 +126,7 @@ Subclasses of [`SingletonInstruction`](#qiskit.circuit.singleton.SingletonInstru #### \_singleton\_lookup\_key - + 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. diff --git a/docs/api/qiskit/classicalfunction.mdx b/docs/api/qiskit/classicalfunction.mdx index 2283ac9ce87..ade7aed1495 100644 --- a/docs/api/qiskit/classicalfunction.mdx +++ b/docs/api/qiskit/classicalfunction.mdx @@ -67,6 +67,24 @@ The type `Int1` means the classical function will only operate at bit level. Decorator for a classical function that returns a ClassicalFunction object. +#### classical\_function + + + Parses and type checks the callable `func` to compile it into an `ClassicalFunction` that can be synthesized into a `QuantumCircuit`. + + **Parameters** + + **func** (*callable*) – A callable (with type hints) to compile into an `ClassicalFunction`. + + **Returns** + + An object that can synthesis into a QuantumCircuit (via `synth()` method). + + **Return type** + + [ClassicalFunction](qiskit.circuit.classicalfunction.ClassicalFunction "qiskit.circuit.classicalfunction.ClassicalFunction") + + ### ClassicalFunction | | | diff --git a/docs/api/qiskit/compiler.mdx b/docs/api/qiskit/compiler.mdx index e73dfef4e38..753bc44154d 100644 --- a/docs/api/qiskit/compiler.mdx +++ b/docs/api/qiskit/compiler.mdx @@ -22,7 +22,7 @@ python_api_name: qiskit.compiler ### assemble - + 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. @@ -66,7 +66,7 @@ python_api_name: qiskit.compiler * `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. + * **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*](circuit#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. @@ -103,7 +103,7 @@ python_api_name: qiskit.compiler ### schedule - + 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** @@ -130,10 +130,22 @@ python_api_name: qiskit.compiler ### transpile - + 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. + 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. + + The prioritization of transpilation target constraints works as follows: if a `target` input is provided, it will take priority over any `backend` input or loose constraints (`basis_gates`, `inst_map`, `coupling_map`, `backend_properties`, `instruction_durations`, `dt` or `timing_constraints`). If a `backend` is provided together with any loose constraint from the list above, the loose constraint will take priority over the corresponding backend constraint. This behavior is independent of whether the `backend` instance is of type [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") or [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2"), as summarized in the table below. The first column in the table summarizes the potential user-provided constraints, and each cell shows whether the priority is assigned to that specific constraint input or another input (target/backend(V1)/backend(V2)). + + | User Provided | target | backend(V1) | backend(V2) | + | -------------------------- | ------ | ---------------------- | ---------------------- | + | **basis\_gates** | target | basis\_gates | basis\_gates | + | **coupling\_map** | target | coupling\_map | coupling\_map | + | **instruction\_durations** | target | instruction\_durations | instruction\_durations | + | **inst\_map** | target | inst\_map | inst\_map | + | **dt** | target | dt | dt | + | **timing\_constraints** | target | timing\_constraints | timing\_constraints | + | **backend\_properties** | target | backend\_properties | backend\_properties | **Parameters** @@ -278,7 +290,7 @@ python_api_name: qiskit.compiler ### sequence - + Schedule a scheduled circuit to a pulse `Schedule`, using the backend. **Parameters** diff --git a/docs/api/qiskit/converters.mdx b/docs/api/qiskit/converters.mdx index 3b6cf7663bc..0c76a992463 100644 --- a/docs/api/qiskit/converters.mdx +++ b/docs/api/qiskit/converters.mdx @@ -18,36 +18,41 @@ python_api_name: qiskit.converters `qiskit.converters` -### circuit\_to\_dag + - - Build a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") object from a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). +## QuantumCircuit -> circuit components + +### circuit\_to\_instruction + + + 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. - * **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. + * **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. - **Returns** + **Raises** - the DAG representing the input circuit. + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if parameter\_map is not compatible with circuit - **Return type** + **Returns** - [DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + an instruction equivalent to the action of the input circuit. Upon decomposition, this instruction will yield the components comprising the original circuit. - **Raises** + **Return type** - [**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. + [qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") **Example** ```python from qiskit import QuantumRegister, ClassicalRegister, QuantumCircuit - from qiskit.dagcircuit import DAGCircuit - from qiskit.converters import circuit_to_dag + from qiskit.converters import circuit_to_instruction q = QuantumRegister(3, 'q') c = ClassicalRegister(3, 'c') @@ -56,27 +61,64 @@ python_api_name: qiskit.converters 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_to_instruction(circ) ``` -### dag\_to\_circuit +### circuit\_to\_gate - - Build a `QuantumCircuit` object from a `DAGCircuit`. + + 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** - * **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). + * **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** - the circuit representing the input dag. + a Gate equivalent to the action of the input circuit. Upon decomposition, this gate will yield the components comprising the original circuit. **Return type** - [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + [Gate](qiskit.circuit.Gate "qiskit.circuit.Gate") + + + + +## QuantumCircuit \<-> DagCircuit + +### circuit\_to\_dag + + + 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*](circuit#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*](circuit#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** @@ -84,8 +126,6 @@ python_api_name: qiskit.converters 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') @@ -95,44 +135,35 @@ python_api_name: qiskit.converters 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/converters-1.png) -### circuit\_to\_instruction - - - Build an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") object from a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). +### dag\_to\_circuit - 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. + + Build a `QuantumCircuit` object from a `DAGCircuit`. **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 + * **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** - an instruction equivalent to the action of the input circuit. Upon decomposition, this instruction will yield the components comprising the original circuit. + the circuit representing the input dag. **Return type** - [qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") **Example** ```python from qiskit import QuantumRegister, ClassicalRegister, QuantumCircuit - from qiskit.converters import circuit_to_instruction + 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') @@ -141,40 +172,21 @@ python_api_name: qiskit.converters 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) + dag = circuit_to_dag(circ) + circuit = dag_to_circuit(dag) + circuit.draw('mpl') ``` - - -### circuit\_to\_gate - - - 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. + ![../\_images/converters-1.png](/images/api/qiskit/converters-1.png) + - **Return type** + - [Gate](qiskit.circuit.Gate "qiskit.circuit.Gate") - +## QuantumCircuit \<-> DagDependency ### dagdependency\_to\_circuit - + Build a `QuantumCircuit` object from a `DAGDependency`. **Parameters** @@ -192,7 +204,7 @@ python_api_name: qiskit.converters ### circuit\_to\_dagdependency - + Build a `DAGDependency` object from a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). **Parameters** @@ -209,9 +221,13 @@ python_api_name: qiskit.converters [DAGDependency](qiskit.dagcircuit.DAGDependency "qiskit.dagcircuit.DAGDependency") + + +## DagCircuit \<-> DagDependency + ### dag\_to\_dagdependency - + Build a `DAGDependency` object from a `DAGCircuit`. **Parameters** @@ -230,7 +246,7 @@ python_api_name: qiskit.converters ### dagdependency\_to\_dag - + Build a `DAGCircuit` object from a `DAGDependency`. **Parameters** diff --git a/docs/api/qiskit/dagcircuit.mdx b/docs/api/qiskit/dagcircuit.mdx index 048c2818175..d2a5d0a5174 100644 --- a/docs/api/qiskit/dagcircuit.mdx +++ b/docs/api/qiskit/dagcircuit.mdx @@ -34,7 +34,7 @@ python_api_name: qiskit.dagcircuit ### DAGCircuitError - + Base class for errors raised by the DAGCircuit object. Set the error message. @@ -42,7 +42,7 @@ python_api_name: qiskit.dagcircuit ### DAGDependencyError - + Base class for errors raised by the DAGDependency object. Set the error message. diff --git a/docs/api/qiskit/dev/_package.json b/docs/api/qiskit/dev/_package.json index 4455624f40c..a4296539994 100644 --- a/docs/api/qiskit/dev/_package.json +++ b/docs/api/qiskit/dev/_package.json @@ -1,4 +1,4 @@ { "name": "qiskit", - "version": "1.1.0rc1" + "version": "1.2.0-dev" } diff --git a/docs/api/qiskit/dev/_toc.json b/docs/api/qiskit/dev/_toc.json index cfe30c9d13e..c47db3c8789 100644 --- a/docs/api/qiskit/dev/_toc.json +++ b/docs/api/qiskit/dev/_toc.json @@ -1529,6 +1529,10 @@ "title": "Sampler", "url": "/api/qiskit/dev/qiskit.primitives.Sampler" }, + { + "title": "SamplerPubResult", + "url": "/api/qiskit/dev/qiskit.primitives.SamplerPubResult" + }, { "title": "SamplerResult", "url": "/api/qiskit/dev/qiskit.primitives.SamplerResult" @@ -2165,6 +2169,10 @@ { "title": "Release notes", "children": [ + { + "title": "1.1", + "url": "/api/qiskit/release-notes/1.1" + }, { "title": "1.0", "url": "/api/qiskit/release-notes/1.0" diff --git a/docs/api/qiskit/dev/assembler.mdx b/docs/api/qiskit/dev/assembler.mdx index f6e6bb4861c..d3befc30868 100644 --- a/docs/api/qiskit/dev/assembler.mdx +++ b/docs/api/qiskit/dev/assembler.mdx @@ -22,7 +22,7 @@ python_api_name: qiskit.assembler ### assemble\_circuits - + Assembles a list of circuits into a qobj that can be run on the backend. **Parameters** @@ -63,7 +63,7 @@ python_api_name: qiskit.assembler ### assemble\_schedules - + Assembles a list of schedules into a qobj that can be run on the backend. **Parameters** @@ -125,7 +125,7 @@ python_api_name: qiskit.assembler ### disassemble - + Disassemble a qobj and return the circuits or pulse schedules, run\_config, and user header. diff --git a/docs/api/qiskit/dev/circuit.mdx b/docs/api/qiskit/dev/circuit.mdx index bd1946ddc15..422bd53bdaa 100644 --- a/docs/api/qiskit/dev/circuit.mdx +++ b/docs/api/qiskit/dev/circuit.mdx @@ -243,10 +243,6 @@ Finally, the circuit module has its own exception class, to indicate when things The main user-facing class for representing circuits is [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). This can be either an abstract circuit or a physical circuit. There is much more information about the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") class itself and the multitude of available methods on it in its class documentation. -| | | -| ---------------------------------------------------------------------------------------------------------------------- | --------------------- | -| [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")(\*regs\[, name, global\_phase, ...]) | Create a new circuit. | - Internally, a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") contains the qubits, classical bits, compile-time parameters, real-time variables, and other tracking information about the data it acts on and how it is parametrized. It then contains a sequence of [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s, which contain the particular operation (gate, measurement, etc) and its operands (the qubits and classical bits). ### Bits and registers @@ -255,7 +251,7 @@ Qubits and classical bits are represented by a shared base [`Bit`](#qiskit.circu #### Bit - + Implement a generic bit. @@ -267,7 +263,7 @@ Qubits and classical bits are represented by a shared base [`Bit`](#qiskit.circu #### Qubit - + Bases: [`Bit`](#qiskit.circuit.Bit "qiskit.circuit.bit.Bit") Implement a quantum bit. @@ -275,7 +271,7 @@ Qubits and classical bits are represented by a shared base [`Bit`](#qiskit.circu #### Clbit - + Bases: [`Bit`](#qiskit.circuit.Bit "qiskit.circuit.bit.Bit") Implement a classical bit. @@ -285,7 +281,7 @@ Qubits and clbits are instantiated by users with no arguments, such as by `Qubit #### AncillaQubit - + Bases: [`Qubit`](#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") A qubit used as ancillary qubit. @@ -295,7 +291,7 @@ A collection bits of the same type can be encapsulated in a register of the matc #### Register - + Implement a generic register. @@ -322,7 +318,7 @@ A collection bits of the same type can be encapsulated in a register of the matc ##### index - + Find the index of the provided bit within this register. @@ -343,7 +339,7 @@ Each of the defined bit subtypes has an associated register, which have the same #### QuantumRegister - + Bases: [`Register`](#qiskit.circuit.Register "qiskit.circuit.register.Register") Implement a quantum register. @@ -351,7 +347,7 @@ Each of the defined bit subtypes has an associated register, which have the same #### ClassicalRegister - + Bases: [`Register`](#qiskit.circuit.Register "qiskit.circuit.register.Register") Implement a classical register. @@ -359,7 +355,7 @@ Each of the defined bit subtypes has an associated register, which have the same #### AncillaRegister - + Bases: [`QuantumRegister`](#qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") Implement an ancilla register. @@ -367,7 +363,7 @@ Each of the defined bit subtypes has an associated register, which have the same A common way to instantiate several bits at once is to create a register, such as by `QuantumRegister("my_qreg", 5)`. This has the advantage that you can give that collection of bits a name, which will appear during circuit visualizations ([`QuantumCircuit.draw()`](qiskit.circuit.QuantumCircuit#draw "qiskit.circuit.QuantumCircuit.draw")) and exports to interchange languages (see [`qasm2`](qasm2#module-qiskit.qasm2 "qiskit.qasm2") and [`qasm3`](qasm3#module-qiskit.qasm3 "qiskit.qasm3")). You can also pass a name and a list of pre-constructed bits, but this creates an “aliasing register”, which are very poorly supported on hardware. -Circuits track registers, but registers themselves impart almost no behavioral differences on circuits. The only exception is that [`ClassicalRegister`](#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")s can be implicitly cast to unsigned integers for use in conditional comparisons of [control flow operations](#circuit-control-flow). +Circuits track registers, but registers themselves impart almost no behavioral differences on circuits. The only exception is that [`ClassicalRegister`](#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")s can be implicitly cast to unsigned integers for use in conditional comparisons of [control flow operations](#circuit-control-flow-repr). Classical registers and bits were the original way of representing classical data in Qiskit, and remain the most supported currently. Longer term, the data model is moving towards a more complete and strongly typed representation of a range of classical data (see [Real-time classical computation](#circuit-repr-real-time-classical)), but you will still very commonly use classical bits in current Qiskit. @@ -389,6 +385,8 @@ The [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCirc This [`InstructionSet`](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") is now little used in Qiskit. It provides a very minimal set of methods to perform post-append mutations on instructions (which *will* be propagated to the circuit), but these are now discouraged and you should use the alternatives noted in those methods. + + ### Operations, instructions and gates Within a [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction"), the minimal interface that any operation must fulfill is [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation"). This is a *very* high level view, and only usable for abstract circuits. The main purpose of treating operations as [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") is to allow arbitrary mathematical objects (such as [`quantum_info.Operator`](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) to be added to abstract circuits directly. @@ -435,19 +433,19 @@ The available modifiers for [`AnnotatedOperation`](qiskit.circuit.AnnotatedOpera #### InverseModifier - + Inverse modifier: specifies that the operation is inverted. #### ControlModifier - + Control modifier: specifies that the operation is controlled by `num_ctrl_qubits` and has control state `ctrl_state`. #### PowerModifier - + Power modifier: specifies that the operation is raised to the power `power`. @@ -461,7 +459,7 @@ Measurements in Qiskit are of a single [`Qubit`](#qiskit.circuit.Qubit "qiskit.c #### Measure - + Bases: [`SingletonInstruction`](circuit_singleton#qiskit.circuit.singleton.SingletonInstruction "qiskit.circuit.singleton.SingletonInstruction") Quantum measurement in the computational basis. @@ -475,7 +473,7 @@ Related to measurements, there is a [`Reset`](#qiskit.circuit.Reset "qiskit.circ #### Reset - + Bases: [`SingletonInstruction`](circuit_singleton#qiskit.circuit.singleton.SingletonInstruction "qiskit.circuit.singleton.SingletonInstruction") Incoherently reset a qubit to the $\lvert0\rangle$ state. @@ -489,7 +487,7 @@ Hardware can be instructed to apply a real-time idle period on a given qubit. A #### Delay - + Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") Do nothing and just delay/wait/idle for a specified duration. @@ -515,7 +513,7 @@ it is forbidden for the optimizer to cancel out the two $X$ instructions. #### Barrier - + Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") 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. @@ -532,7 +530,7 @@ The [`Store`](#qiskit.circuit.Store "qiskit.circuit.Store") instruction is parti #### Store - + Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") A manual storage of some classical value to a classical memory location. @@ -561,10 +559,14 @@ The [`Store`](#qiskit.circuit.Store "qiskit.circuit.Store") instruction is parti ### Real-time classical computation - - The primary documentation for real-time classical computation is in the module-level documentation of [`qiskit.circuit.classical`](circuit_classical#module-qiskit.circuit.classical "qiskit.circuit.classical"). + + **[`qiskit.circuit.classical`](circuit_classical#module-qiskit.circuit.classical "qiskit.circuit.classical")** + + Module-level documentation for how the variable-, expression- and type-systems work, the objects used to represent them, and the classical operations available. - You might also want to read about the circuit methods for working with real-time variables on the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") class page. + **[Working with real-time typed classical data](qiskit.circuit.QuantumCircuit#circuit-real-time-methods)** + + The [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") methods for working with these variables in the context of a single circuit. Qiskit has rudimentary low-level support for representing real-time classical computations, which happen during the QPU execution and affect the results. We are still relatively early into hardware support for these concepts as well, so beware that you will need to work closely with your hardware provider’s documentation to get the best use out of any real-time classical computation. @@ -598,7 +600,7 @@ You may want to use many parameters that are related to each other. To make this | ----------------------------------------------------------------------------------------------------- | -------------------------------------------------------------- | | [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector")(name\[, length]) | ParameterVector class to quickly generate lists of parameters. | - + ### Control flow in circuits @@ -632,6 +634,8 @@ In addition to the block-structure control-flow operations, there are also two s The classes representations are documented here, but please note that manually constructing these classes is a low-level operation that we do not expect users to need to do frequently. + + Users should read [Adding control flow to circuits](qiskit.circuit.QuantumCircuit#circuit-control-flow-methods) for the recommended workflows for building control-flow-enabled circuits. Since [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") subclasses are also [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") subclasses, this means that the way they are stored in [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") instances has them “applied” to a sequence of qubits and clbits in its [`qubits`](qiskit.circuit.CircuitInstruction#qubits "qiskit.circuit.CircuitInstruction.qubits") and [`clbits`](qiskit.circuit.CircuitInstruction#clbits "qiskit.circuit.CircuitInstruction.clbits") attributes. This can lead to subtle data-coherence problems: the [`Qubit`](#qiskit.circuit.Qubit "qiskit.circuit.Qubit") and [`Clbit`](#qiskit.circuit.Clbit "qiskit.circuit.Clbit") objects used inside the subcircuit blocks of the control-flow ops will not necessarily be identical to the corresponding objects in the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction"). Any code that consumes control-flow operations in Qiskit needs to be aware of this; within a subcircuit, you should treat `subcircuit.qubits[i]` as if it were really `outer_instruction.qubits[i]`, and so on. You can generate an easy lookup table for this by doing: @@ -655,6 +659,8 @@ Any [`ClassicalRegister`](#qiskit.circuit.ClassicalRegister "qiskit.circuit.Clas When the low-level construction is being used the inner [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") blocks must manually close over any outer-scope [real-time classical computation variables](#circuit-repr-real-time-classical) that they use. This is marked by these being in the [`iter_captured_vars()`](qiskit.circuit.QuantumCircuit#iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars") iterator for that block. Libraries constructing these blocks manually will need to track these captures when building control-flow circuit blocks and add them to the block using [`add_capture()`](qiskit.circuit.QuantumCircuit#add_capture "qiskit.circuit.QuantumCircuit.add_capture") (or the `captures` constructor argument), but user code will typically use the control-flow builder interface, which handles this automatically. +Consult [the control-flow construction documentation](qiskit.circuit.QuantumCircuit#circuit-control-flow-methods) for more information on how to build circuits with control flow. + ## Creating custom instructions @@ -673,7 +679,7 @@ Subclasses of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruc #### \_define - + Populate the cached `_definition` field of this [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"). Subclasses should implement this method to provide lazy construction of their public [`definition`](qiskit.circuit.Instruction#definition "qiskit.circuit.Instruction.definition") attribute. A subclass can use its [`params`](qiskit.circuit.Instruction#params "qiskit.circuit.Instruction.params") at the time of the call. The method should populate `_definition` with a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") and not return a value. @@ -760,93 +766,6 @@ After this, for the duration of the Python interpreter session, translators like ## Working with circuit-level objects -### 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-2.png](/images/api/qiskit/dev/circuit-2.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/dev/depth.gif) - -We can verify our graphical result using [`QuantumCircuit.depth()`](qiskit.circuit.QuantumCircuit#depth "qiskit.circuit.QuantumCircuit.depth"): - -```python -qc.depth() -``` - -```python -9 -``` - ### Converting abstract circuits to physical circuits @@ -896,7 +815,7 @@ The default instance of [`EquivalenceLibrary`](qiskit.circuit.EquivalenceLibrary #### random\_circuit - + 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: @@ -908,7 +827,7 @@ The default instance of [`EquivalenceLibrary`](qiskit.circuit.EquivalenceLibrary circ.draw(output='mpl') ``` - ![../\_images/circuit-3.png](/images/api/qiskit/dev/circuit-3.png) + ![../\_images/circuit-2.png](/images/api/qiskit/dev/circuit-2.png) **Parameters** @@ -939,7 +858,7 @@ Almost all circuit functions and methods will raise a [`CircuitError`](#qiskit.c ### CircuitError - + Base class for errors raised while processing a circuit. Set the error message. @@ -985,7 +904,7 @@ If we draw this circuit, we will see that Qiskit places the zeroth qubit on the qc.draw("mpl") ``` -![../\_images/circuit-5.png](/images/api/qiskit/dev/circuit-5.png) +![../\_images/circuit-4.png](/images/api/qiskit/dev/circuit-4.png) ### Matrix representations diff --git a/docs/api/qiskit/dev/circuit_classical.mdx b/docs/api/qiskit/dev/circuit_classical.mdx index e30c1607eab..988c762056a 100644 --- a/docs/api/qiskit/dev/circuit_classical.mdx +++ b/docs/api/qiskit/dev/circuit_classical.mdx @@ -50,7 +50,7 @@ The expression system is based on tree representation. All nodes in the tree are #### Expr - + 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. @@ -64,10 +64,10 @@ The base for dynamic variables is the [`Var`](#qiskit.circuit.classical.expr.Var #### Var - + A classical variable. - These variables take two forms: a new-style variable that owns its storage location and has an associated name; and an old-style variable that wraps a [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") or [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") instance that is owned by some containing circuit. In general, construction of variables for use in programs should use `Var.new()` or [`QuantumCircuit.add_var()`](qiskit.circuit.QuantumCircuit#add_var "qiskit.circuit.QuantumCircuit.add_var"). + These variables take two forms: a new-style variable that owns its storage location and has an associated name; and an old-style variable that wraps a [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") or [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") instance that is owned by some containing circuit. In general, construction of variables for use in programs should use [`Var.new()`](#qiskit.circuit.classical.expr.Var.new "qiskit.circuit.classical.expr.Var.new") or [`QuantumCircuit.add_var()`](qiskit.circuit.QuantumCircuit#add_var "qiskit.circuit.QuantumCircuit.add_var"). Variables are immutable after construction, so they can be used as dictionary keys. @@ -77,6 +77,16 @@ The base for dynamic variables is the [`Var`](#qiskit.circuit.classical.expr.Var The name of the variable. This is required to exist if the backing [`var`](#qiskit.circuit.classical.expr.Var.var "qiskit.circuit.classical.expr.Var.var") attribute is a [`UUID`](https://docs.python.org/3/library/uuid.html#uuid.UUID "(in Python v3.12)"), i.e. if it is a new-style variable, and must be `None` if it is an old-style variable. + ##### new + + + Generate a new named variable that owns its own backing storage. + + **Return type** + + [*Self*](https://docs.python.org/3/library/typing.html#typing.Self "(in Python v3.12)") + + ##### var @@ -88,7 +98,7 @@ Similarly, literals used in expressions (such as integers) should be lifted to [ #### Value - + A single scalar value. @@ -96,7 +106,7 @@ The operations traditionally associated with pre-, post- or infix operators in p #### Unary - + A unary expression. **Parameters** @@ -107,7 +117,7 @@ The operations traditionally associated with pre-, post- or infix operators in p ##### Op - + 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. @@ -130,7 +140,7 @@ The operations traditionally associated with pre-, post- or infix operators in p #### Binary - + A binary expression. **Parameters** @@ -142,7 +152,7 @@ The operations traditionally associated with pre-, post- or infix operators in p ##### Op - + 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. @@ -237,7 +247,7 @@ Bit-like types (unsigned integers) can be indexed by integer types, represented #### Index - + An indexing expression. **Parameters** @@ -253,7 +263,7 @@ Expressions in this system are defined to act only on certain sets of types. How #### Cast - + A cast from one type to another, implied by the use of an expression in a different context. @@ -267,7 +277,7 @@ The functions and methods described in this section are a more user-friendly way #### lift - + 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. @@ -301,13 +311,13 @@ The functions and methods described in this section are a more user-friendly way [Expr](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") -Typically you should create memory-owning [`Var`](#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instances by using the [`QuantumCircuit.add_var()`](qiskit.circuit.QuantumCircuit#add_var "qiskit.circuit.QuantumCircuit.add_var") method to declare them in some circuit context, since a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") will not accept an [`Expr`](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") that contains variables that are not already declared in it, since it needs to know how to allocate the storage and how the variable will be initialized. However, should you want to do this manually, you should use the low-level `Var.new()` call to safely generate a named variable for usage. +Typically you should create memory-owning [`Var`](#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instances by using the [`QuantumCircuit.add_var()`](qiskit.circuit.QuantumCircuit#add_var "qiskit.circuit.QuantumCircuit.add_var") method to declare them in some circuit context, since a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") will not accept an [`Expr`](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") that contains variables that are not already declared in it, since it needs to know how to allocate the storage and how the variable will be initialized. However, should you want to do this manually, you should use the low-level [`Var.new()`](#qiskit.circuit.classical.expr.Var.new "qiskit.circuit.classical.expr.Var.new") call to safely generate a named variable for usage. 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 - + Create an explicit cast from the given value to the given type. **Examples** @@ -330,7 +340,7 @@ There are helper constructor functions for each of the unary operations. #### bit\_not - + 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** @@ -351,7 +361,7 @@ There are helper constructor functions for each of the unary operations. #### logic\_not - + 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** @@ -374,7 +384,7 @@ Similarly, the binary operations and relations have helper functions defined. #### bit\_and - + 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** @@ -395,7 +405,7 @@ Similarly, the binary operations and relations have helper functions defined. #### bit\_or - + 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** @@ -416,7 +426,7 @@ Similarly, the binary operations and relations have helper functions defined. #### bit\_xor - + 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** @@ -437,7 +447,7 @@ Similarly, the binary operations and relations have helper functions defined. #### logic\_and - + 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** @@ -458,7 +468,7 @@ Similarly, the binary operations and relations have helper functions defined. #### logic\_or - + 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** @@ -479,7 +489,7 @@ Similarly, the binary operations and relations have helper functions defined. #### equal - + 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** @@ -500,7 +510,7 @@ Similarly, the binary operations and relations have helper functions defined. #### not\_equal - + 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** @@ -521,7 +531,7 @@ Similarly, the binary operations and relations have helper functions defined. #### less - + 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** @@ -542,7 +552,7 @@ Similarly, the binary operations and relations have helper functions defined. #### less\_equal - + 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** @@ -563,7 +573,7 @@ Similarly, the binary operations and relations have helper functions defined. #### greater - + 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** @@ -584,7 +594,7 @@ Similarly, the binary operations and relations have helper functions defined. #### greater\_equal - + 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** @@ -605,7 +615,7 @@ Similarly, the binary operations and relations have helper functions defined. #### shift\_left - + Create a ‘bitshift left’ expression node from the given two values, resolving any implicit casts and lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. If `type` is given, the `left` operand will be coerced to it (if possible). @@ -635,7 +645,7 @@ Similarly, the binary operations and relations have helper functions defined. #### shift\_right - + Create a ‘bitshift right’ expression node from the given values, resolving any implicit casts and lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. If `type` is given, the `left` operand will be coerced to it (if possible). @@ -660,7 +670,7 @@ You can index into unsigned integers and bit-likes using another unsigned intege #### index - + Index into the `target` with the given integer `index`, lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. This can be used as the target of a [`Store`](circuit#qiskit.circuit.Store "qiskit.circuit.Store"), if the `target` is itself an lvalue. @@ -685,7 +695,7 @@ Qiskit’s legacy method for specifying equality conditions for use in condition #### lift\_legacy\_condition - + Lift a legacy two-tuple equality condition into a new-style [`Expr`](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr"). **Examples** @@ -714,12 +724,12 @@ A typical consumer of the expression tree wants to recursively walk through the #### ExprVisitor - + 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 - + **Return type** *\_T\_co* @@ -727,7 +737,7 @@ A typical consumer of the expression tree wants to recursively walk through the ##### visit\_cast - + **Return type** *\_T\_co* @@ -735,7 +745,7 @@ A typical consumer of the expression tree wants to recursively walk through the ##### visit\_generic - + **Return type** *\_T\_co* @@ -743,7 +753,7 @@ A typical consumer of the expression tree wants to recursively walk through the ##### visit\_index - + **Return type** *\_T\_co* @@ -751,7 +761,7 @@ A typical consumer of the expression tree wants to recursively walk through the ##### visit\_unary - + **Return type** *\_T\_co* @@ -759,7 +769,7 @@ A typical consumer of the expression tree wants to recursively walk through the ##### visit\_value - + **Return type** *\_T\_co* @@ -767,7 +777,7 @@ A typical consumer of the expression tree wants to recursively walk through the ##### visit\_var - + **Return type** *\_T\_co* @@ -780,7 +790,7 @@ For the convenience of simple visitors that only need to inspect the variables i #### iter\_vars - + 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** @@ -808,7 +818,7 @@ Two expressions can be compared for direct structural equality by using the buil #### structurally\_equivalent - + 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`](#qiskit.circuit.classical.expr.Var.var "qiskit.circuit.classical.expr.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). @@ -855,7 +865,7 @@ Some expressions have associated memory locations, and others may be purely temp #### is\_lvalue - + Return whether this expression can be used in l-value positions, that is, whether it has a well-defined location in memory, such as one that might be writeable. Being an l-value is a necessary but not sufficient for this location to be writeable; it is permissible that a larger object containing this memory location may not allow writing from the scope that attempts to write to it. This would be an access property of the containing program, however, and not an inherent property of the expression system. @@ -917,7 +927,7 @@ All types inherit from an abstract base class: #### Type - + 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. @@ -929,13 +939,13 @@ The two different types available are for Booleans (corresponding to [`Clbit`](c #### Bool - + The Boolean type. This has exactly two values: `True` and `False`. #### Uint - + An unsigned integer of fixed bit width. @@ -953,7 +963,7 @@ The low-level interface to querying the subtyping relationship is the [`order()` #### order - + Get the ordering relationship between the two types as an enumeration value. **Examples** @@ -982,7 +992,7 @@ The return value is an enumeration [`Ordering`](#qiskit.circuit.classical.types. #### Ordering - + 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. @@ -992,7 +1002,7 @@ Some helper methods are then defined in terms of this low-level [`order()`](#qis #### is\_subtype - + 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** @@ -1021,7 +1031,7 @@ Some helper methods are then defined in terms of this low-level [`order()`](#qis #### is\_supertype - + 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** @@ -1050,7 +1060,7 @@ Some helper methods are then defined in terms of this low-level [`order()`](#qis #### greater - + 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** @@ -1082,7 +1092,7 @@ It is common to need to cast values of one type to another type. The casting rul #### cast\_kind - + Determine the sort of cast that is required to move from the left type to the right type. **Examples** @@ -1108,7 +1118,7 @@ The return values from this function are an enumeration explaining the types of #### CastKind - + A return value indicating the type of cast that can occur from one type to another. diff --git a/docs/api/qiskit/dev/circuit_library.mdx b/docs/api/qiskit/dev/circuit_library.mdx index 78306b93839..23b3cbef20e 100644 --- a/docs/api/qiskit/dev/circuit_library.mdx +++ b/docs/api/qiskit/dev/circuit_library.mdx @@ -322,7 +322,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_2a\_1 - + **Returns** template as a quantum circuit. @@ -334,7 +334,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_2a\_2 - + **Returns** template as a quantum circuit. @@ -346,7 +346,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_2a\_3 - + **Returns** template as a quantum circuit. @@ -358,7 +358,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_4a\_1 - + **Returns** template as a quantum circuit. @@ -370,7 +370,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_4a\_2 - + **Returns** template as a quantum circuit. @@ -382,7 +382,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_4a\_3 - + **Returns** template as a quantum circuit. @@ -394,7 +394,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_4b\_1 - + **Returns** template as a quantum circuit. @@ -406,7 +406,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_4b\_2 - + **Returns** template as a quantum circuit. @@ -418,7 +418,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_5a\_1 - + **Returns** template as a quantum circuit. @@ -430,7 +430,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_5a\_2 - + **Returns** template as a quantum circuit. @@ -442,7 +442,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_5a\_3 - + **Returns** template as a quantum circuit. @@ -454,7 +454,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_5a\_4 - + **Returns** template as a quantum circuit. @@ -466,7 +466,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_6a\_1 - + **Returns** template as a quantum circuit. @@ -478,7 +478,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_6a\_2 - + **Returns** template as a quantum circuit. @@ -490,7 +490,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_6a\_3 - + **Returns** template as a quantum circuit. @@ -502,7 +502,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_6a\_4 - + **Returns** template as a quantum circuit. @@ -514,7 +514,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_6b\_1 - + **Returns** template as a quantum circuit. @@ -526,7 +526,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_6b\_2 - + **Returns** template as a quantum circuit. @@ -538,7 +538,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_6c\_1 - + **Returns** template as a quantum circuit. @@ -550,7 +550,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_7a\_1 - + **Returns** template as a quantum circuit. @@ -562,7 +562,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_7b\_1 - + **Returns** template as a quantum circuit. @@ -574,7 +574,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_7c\_1 - + **Returns** template as a quantum circuit. @@ -586,7 +586,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_7d\_1 - + **Returns** template as a quantum circuit. @@ -598,7 +598,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_7e\_1 - + **Returns** template as a quantum circuit. @@ -610,7 +610,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9a\_1 - + **Returns** template as a quantum circuit. @@ -622,7 +622,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_1 - + **Returns** template as a quantum circuit. @@ -634,7 +634,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_2 - + **Returns** template as a quantum circuit. @@ -646,7 +646,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_3 - + **Returns** template as a quantum circuit. @@ -658,7 +658,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_4 - + **Returns** template as a quantum circuit. @@ -670,7 +670,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_5 - + **Returns** template as a quantum circuit. @@ -682,7 +682,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_6 - + **Returns** template as a quantum circuit. @@ -694,7 +694,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_7 - + **Returns** template as a quantum circuit. @@ -706,7 +706,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_8 - + **Returns** template as a quantum circuit. @@ -718,7 +718,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_9 - + **Returns** template as a quantum circuit. @@ -730,7 +730,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_10 - + **Returns** template as a quantum circuit. @@ -742,7 +742,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_11 - + **Returns** template as a quantum circuit. @@ -754,7 +754,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9c\_12 - + **Returns** template as a quantum circuit. @@ -766,7 +766,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_1 - + **Returns** template as a quantum circuit. @@ -778,7 +778,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_2 - + **Returns** template as a quantum circuit. @@ -790,7 +790,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_3 - + **Returns** template as a quantum circuit. @@ -802,7 +802,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_4 - + **Returns** template as a quantum circuit. @@ -814,7 +814,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_5 - + **Returns** template as a quantum circuit. @@ -826,7 +826,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_6 - + **Returns** template as a quantum circuit. @@ -838,7 +838,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_7 - + **Returns** template as a quantum circuit. @@ -850,7 +850,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_8 - + **Returns** template as a quantum circuit. @@ -862,7 +862,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_9 - + **Returns** template as a quantum circuit. @@ -874,7 +874,7 @@ Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.lib #### template\_nct\_9d\_10 - + **Returns** template as a quantum circuit. @@ -890,7 +890,7 @@ Template circuits over Clifford gates. #### clifford\_2\_1 - + **Returns** template as a quantum circuit. @@ -902,7 +902,7 @@ Template circuits over Clifford gates. #### clifford\_2\_2 - + **Returns** template as a quantum circuit. @@ -914,7 +914,7 @@ Template circuits over Clifford gates. #### clifford\_2\_3 - + **Returns** template as a quantum circuit. @@ -926,7 +926,7 @@ Template circuits over Clifford gates. #### clifford\_2\_4 - + **Returns** template as a quantum circuit. @@ -938,7 +938,7 @@ Template circuits over Clifford gates. #### clifford\_3\_1 - + **Returns** template as a quantum circuit. @@ -950,7 +950,7 @@ Template circuits over Clifford gates. #### clifford\_4\_1 - + **Returns** template as a quantum circuit. @@ -962,7 +962,7 @@ Template circuits over Clifford gates. #### clifford\_4\_2 - + **Returns** template as a quantum circuit. @@ -974,7 +974,7 @@ Template circuits over Clifford gates. #### clifford\_4\_3 - + **Returns** template as a quantum circuit. @@ -986,7 +986,7 @@ Template circuits over Clifford gates. #### clifford\_4\_4 - + **Returns** template as a quantum circuit. @@ -998,7 +998,7 @@ Template circuits over Clifford gates. #### clifford\_5\_1 - + **Returns** template as a quantum circuit. @@ -1010,7 +1010,7 @@ Template circuits over Clifford gates. #### clifford\_6\_1 - + **Returns** template as a quantum circuit. @@ -1022,7 +1022,7 @@ Template circuits over Clifford gates. #### clifford\_6\_2 - + **Returns** template as a quantum circuit. @@ -1034,7 +1034,7 @@ Template circuits over Clifford gates. #### clifford\_6\_3 - + **Returns** template as a quantum circuit. @@ -1046,7 +1046,7 @@ Template circuits over Clifford gates. #### clifford\_6\_4 - + **Returns** template as a quantum circuit. @@ -1058,7 +1058,7 @@ Template circuits over Clifford gates. #### clifford\_6\_5 - + **Returns** template as a quantum circuit. @@ -1070,7 +1070,7 @@ Template circuits over Clifford gates. #### clifford\_8\_1 - + **Returns** template as a quantum circuit. @@ -1082,7 +1082,7 @@ Template circuits over Clifford gates. #### clifford\_8\_2 - + **Returns** template as a quantum circuit. @@ -1094,7 +1094,7 @@ Template circuits over Clifford gates. #### clifford\_8\_3 - + **Returns** template as a quantum circuit. @@ -1110,37 +1110,37 @@ Template circuits with [`RZXGate`](qiskit.circuit.library.RZXGate "qiskit.circui #### rzx\_yz - + Template for CX - RYGate - CX. #### rzx\_xz - + Template for CX - RXGate - CX. #### rzx\_cy - + Template for CX - RYGate - CX. #### rzx\_zz1 - + Template for CX - RZGate - CX. #### rzx\_zz2 - + Template for CX - RZGate - CX. #### rzx\_zz3 - + Template for CX - RZGate - CX. diff --git a/docs/api/qiskit/dev/circuit_singleton.mdx b/docs/api/qiskit/dev/circuit_singleton.mdx index aed0e118dbb..8dd49196d08 100644 --- a/docs/api/qiskit/dev/circuit_singleton.mdx +++ b/docs/api/qiskit/dev/circuit_singleton.mdx @@ -46,7 +46,7 @@ The public classes correspond to the standard classes [`Instruction`](qiskit.cir ### SingletonInstruction - + 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`](circuit#qiskit.circuit.Measure "qiskit.circuit.Measure") which has an immutable definition and any instance of [`Measure`](circuit#qiskit.circuit.Measure "qiskit.circuit.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. @@ -56,7 +56,7 @@ The public classes correspond to the standard classes [`Instruction`](qiskit.cir ### SingletonGate - + 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. @@ -64,7 +64,7 @@ The public classes correspond to the standard classes [`Instruction`](qiskit.cir ### SingletonControlledGate - + 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. @@ -126,7 +126,7 @@ Subclasses of [`SingletonInstruction`](#qiskit.circuit.singleton.SingletonInstru #### \_singleton\_lookup\_key - + 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. diff --git a/docs/api/qiskit/dev/classicalfunction.mdx b/docs/api/qiskit/dev/classicalfunction.mdx index ade7aed1495..9d308993da9 100644 --- a/docs/api/qiskit/dev/classicalfunction.mdx +++ b/docs/api/qiskit/dev/classicalfunction.mdx @@ -69,7 +69,7 @@ Decorator for a classical function that returns a ClassicalFunction object. #### classical\_function - + Parses and type checks the callable `func` to compile it into an `ClassicalFunction` that can be synthesized into a `QuantumCircuit`. **Parameters** diff --git a/docs/api/qiskit/dev/compiler.mdx b/docs/api/qiskit/dev/compiler.mdx index 753bc44154d..e601b7e2f7a 100644 --- a/docs/api/qiskit/dev/compiler.mdx +++ b/docs/api/qiskit/dev/compiler.mdx @@ -22,7 +22,7 @@ python_api_name: qiskit.compiler ### assemble - + 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. @@ -103,7 +103,7 @@ python_api_name: qiskit.compiler ### schedule - + 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** @@ -130,7 +130,7 @@ python_api_name: qiskit.compiler ### transpile - + 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. @@ -290,7 +290,7 @@ python_api_name: qiskit.compiler ### sequence - + Schedule a scheduled circuit to a pulse `Schedule`, using the backend. **Parameters** diff --git a/docs/api/qiskit/dev/converters.mdx b/docs/api/qiskit/dev/converters.mdx index 708c1ee730f..c79190173f6 100644 --- a/docs/api/qiskit/dev/converters.mdx +++ b/docs/api/qiskit/dev/converters.mdx @@ -24,7 +24,7 @@ python_api_name: qiskit.converters ### circuit\_to\_instruction - + 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. @@ -67,7 +67,7 @@ python_api_name: qiskit.converters ### circuit\_to\_gate - + 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. @@ -98,7 +98,7 @@ python_api_name: qiskit.converters ### circuit\_to\_dag - + Build a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") object from a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). **Parameters** @@ -140,7 +140,7 @@ python_api_name: qiskit.converters ### dag\_to\_circuit - + Build a `QuantumCircuit` object from a `DAGCircuit`. **Parameters** @@ -186,7 +186,7 @@ python_api_name: qiskit.converters ### dagdependency\_to\_circuit - + Build a `QuantumCircuit` object from a `DAGDependency`. **Parameters** @@ -204,7 +204,7 @@ python_api_name: qiskit.converters ### circuit\_to\_dagdependency - + Build a `DAGDependency` object from a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). **Parameters** @@ -227,7 +227,7 @@ python_api_name: qiskit.converters ### dag\_to\_dagdependency - + Build a `DAGDependency` object from a `DAGCircuit`. **Parameters** @@ -246,7 +246,7 @@ python_api_name: qiskit.converters ### dagdependency\_to\_dag - + Build a `DAGCircuit` object from a `DAGDependency`. **Parameters** diff --git a/docs/api/qiskit/dev/dagcircuit.mdx b/docs/api/qiskit/dev/dagcircuit.mdx index d2a5d0a5174..872cf1a1710 100644 --- a/docs/api/qiskit/dev/dagcircuit.mdx +++ b/docs/api/qiskit/dev/dagcircuit.mdx @@ -23,10 +23,10 @@ python_api_name: qiskit.dagcircuit | | | | ----------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------- | | [`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. | +| [`DAGNode`](qiskit.dagcircuit.DAGNode "qiskit.dagcircuit.DAGNode") | Parent class for DAGOpNode, DAGInNode, and DAGOutNode. | +| [`DAGOpNode`](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode") | Object to represent an Instruction at a node in the DAGCircuit. | +| [`DAGInNode`](qiskit.dagcircuit.DAGInNode "qiskit.dagcircuit.DAGInNode") | Object to represent an incoming wire node in the DAGCircuit. | +| [`DAGOutNode`](qiskit.dagcircuit.DAGOutNode "qiskit.dagcircuit.DAGOutNode") | 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. | @@ -34,7 +34,7 @@ python_api_name: qiskit.dagcircuit ### DAGCircuitError - + Base class for errors raised by the DAGCircuit object. Set the error message. @@ -42,7 +42,7 @@ python_api_name: qiskit.dagcircuit ### DAGDependencyError - + Base class for errors raised by the DAGDependency object. Set the error message. diff --git a/docs/api/qiskit/dev/exceptions.mdx b/docs/api/qiskit/dev/exceptions.mdx index c03e83fcf6d..61496e7b1ca 100644 --- a/docs/api/qiskit/dev/exceptions.mdx +++ b/docs/api/qiskit/dev/exceptions.mdx @@ -24,7 +24,7 @@ All Qiskit-related exceptions raised by Qiskit are subclasses of the base: ### QiskitError - + Base class for errors raised by Qiskit. Set the error message. @@ -40,7 +40,7 @@ Qiskit has several optional features that depend on other packages that are not ### MissingOptionalLibraryError - + 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 @@ -50,7 +50,7 @@ Two more uncommon errors relate to failures in reading user-configuration files, ### QiskitUserConfigError - + Raised when an error is encountered reading a user config file. Set the error message. @@ -58,7 +58,7 @@ Two more uncommon errors relate to failures in reading user-configuration files, ### InvalidFileError - + Raised when the file provided is not valid for the specific task. Set the error message. @@ -70,7 +70,7 @@ Some particular features of Qiskit may raise custom warnings. In general, Qiskit ### QiskitWarning - + Common subclass of warnings for Qiskit-specific warnings being raised. @@ -78,7 +78,7 @@ Related to [`MissingOptionalLibraryError`](#qiskit.exceptions.MissingOptionalLib ### OptionalDependencyImportWarning - + Raised when an optional library raises errors during its import. @@ -90,7 +90,7 @@ When experimental features are being used, Qiskit will raise [`ExperimentalWarni ### ExperimentalWarning - + Raised when an experimental feature is being used. diff --git a/docs/api/qiskit/dev/index.mdx b/docs/api/qiskit/dev/index.mdx index a00706cc213..b46c80cebc6 100644 --- a/docs/api/qiskit/dev/index.mdx +++ b/docs/api/qiskit/dev/index.mdx @@ -13,6 +13,7 @@ python_api_name: qiskit Circuit construction: * [Quantum circuit model (`qiskit.circuit`)](circuit) +* [`QuantumCircuit` class](qiskit.circuit.QuantumCircuit) * [Classical expressions (`qiskit.circuit.classical`)](circuit_classical) * [ClassicalFunction compiler (`qiskit.circuit.classicalfunction`)](classicalfunction) * [Circuit Library (`qiskit.circuit.library`)](circuit_library) diff --git a/docs/api/qiskit/dev/passmanager.mdx b/docs/api/qiskit/dev/passmanager.mdx index f9c7d4bddd6..3da54294916 100644 --- a/docs/api/qiskit/dev/passmanager.mdx +++ b/docs/api/qiskit/dev/passmanager.mdx @@ -162,7 +162,7 @@ With the pass manager framework, a developer can flexibly customize the optimiza #### PassManagerError - + Pass manager error. Set the error message. diff --git a/docs/api/qiskit/dev/primitives.mdx b/docs/api/qiskit/dev/primitives.mdx index 9a0e9f116c9..1c7fb04969b 100644 --- a/docs/api/qiskit/dev/primitives.mdx +++ b/docs/api/qiskit/dev/primitives.mdx @@ -328,6 +328,7 @@ The formal distinction between the Primitives V1 and V2 APIs are the base classe | [`DataBin`](qiskit.primitives.DataBin "qiskit.primitives.DataBin")(\*\[, shape]) | Namespace for storing data. | | [`PrimitiveResult`](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")(pub\_results\[, metadata]) | A container for multiple pub results and global metadata. | | [`PubResult`](qiskit.primitives.PubResult "qiskit.primitives.PubResult")(data\[, metadata]) | Result of Primitive Unified Bloc. | +| [`SamplerPubResult`](qiskit.primitives.SamplerPubResult "qiskit.primitives.SamplerPubResult")(data\[, metadata]) | Result of Sampler Pub. | | [`BasePrimitiveJob`](qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob")(job\_id, \*\*kwargs) | Primitive job abstract base class. | | [`PrimitiveJob`](qiskit.primitives.PrimitiveJob "qiskit.primitives.PrimitiveJob")(function, \*args, \*\*kwargs) | Primitive job class for the reference implementations of Primitives. | diff --git a/docs/api/qiskit/dev/providers.mdx b/docs/api/qiskit/dev/providers.mdx index 4e3e0f3c2be..59493b43755 100644 --- a/docs/api/qiskit/dev/providers.mdx +++ b/docs/api/qiskit/dev/providers.mdx @@ -77,7 +77,7 @@ It’s worth pointing out that Qiskit’s version support policy doesn’t mean #### QiskitBackendNotFoundError - + Base class for errors raised while looking for a backend. Set the error message. @@ -85,7 +85,7 @@ It’s worth pointing out that Qiskit’s version support policy doesn’t mean #### BackendPropertyError - + Base class for errors raised while looking for a backend property. Set the error message. @@ -93,7 +93,7 @@ It’s worth pointing out that Qiskit’s version support policy doesn’t mean #### JobError - + Base class for errors raised by Jobs. Set the error message. @@ -101,7 +101,7 @@ It’s worth pointing out that Qiskit’s version support policy doesn’t mean #### JobTimeoutError - + Base class for timeout errors raised by jobs. Set the error message. @@ -109,7 +109,7 @@ It’s worth pointing out that Qiskit’s version support policy doesn’t mean #### BackendConfigurationError - + Base class for errors raised by the BackendConfiguration. Set the error message. @@ -332,8 +332,36 @@ This snippet of a backend implementation will now have the [`transpile()`](compi 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. + + +#### Real-time variables + +The transpiler will automatically handle real-time typed classical variables (see [`qiskit.circuit.classical`](circuit_classical#module-qiskit.circuit.classical "qiskit.circuit.classical")) and treat the [`Store`](circuit#qiskit.circuit.Store "qiskit.circuit.Store") instruction as a built-in “directive”, similar to [`Barrier`](circuit#qiskit.circuit.Barrier "qiskit.circuit.Barrier"). No special handling from backends is necessary to permit this. + +If your backend is *unable* to handle classical variables and storage, we recommend that you comment on this in your documentation, and insert a check into your [`run()`](qiskit.providers.BackendV2#run "qiskit.providers.BackendV2.run") method (see [Backend.run Method](#providers-guide-backend-run)) to eagerly reject circuits containing them. You can examine [`QuantumCircuit.num_vars`](qiskit.circuit.QuantumCircuit#num_vars "qiskit.circuit.QuantumCircuit.num_vars") for the presence of variables at the top level. If you accept [control-flow operations](circuit#circuit-control-flow-repr), you might need to recursively search the internal [`blocks`](qiskit.circuit.ControlFlowOp#blocks "qiskit.circuit.ControlFlowOp.blocks") of each for scope-local variables with [`QuantumCircuit.num_declared_vars`](qiskit.circuit.QuantumCircuit#num_declared_vars "qiskit.circuit.QuantumCircuit.num_declared_vars"). + +For example, a function to check for the presence of any manual storage locations, or manual stores to memory: + +```python +from qiskit.circuit import Store, ControlFlowOp, QuantumCircuit + +def has_realtime_logic(circuit: QuantumCircuit) -> bool: + if circuit.num_vars: + return True + for instruction in circuit.data: + if isinstance(instruction.operation, Store): + return True + elif isinstance(instruction.operation, ControlFlowOp): + for block in instruction.operation.blocks: + if has_realtime_logic(block): + return True + return False +``` + + + ### Backend.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 IBM backends from the `qiskit-ibm-provider` package this involves converting from a quantum circuit and options into a [`qpy`](qpy#module-qiskit.qpy "qiskit.qpy") payload embedded in JSON 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. diff --git a/docs/api/qiskit/dev/providers_fake_provider.mdx b/docs/api/qiskit/dev/providers_fake_provider.mdx index 7847c244d3c..e8d22fa1e8a 100644 --- a/docs/api/qiskit/dev/providers_fake_provider.mdx +++ b/docs/api/qiskit/dev/providers_fake_provider.mdx @@ -83,7 +83,7 @@ The V1 fake backends are based on a set of base classes: ### FakeBackend - + This is a dummy backend just for testing purposes. FakeBackend initializer. @@ -96,7 +96,7 @@ The V1 fake backends are based on a set of base classes: ### FakeQasmBackend - + A fake OpenQASM backend. FakeBackend initializer. @@ -109,7 +109,7 @@ The V1 fake backends are based on a set of base classes: ### FakePulseBackend - + A fake pulse backend. FakeBackend initializer. diff --git a/docs/api/qiskit/dev/pulse.mdx b/docs/api/qiskit/dev/pulse.mdx index 9d756120f19..beb71a6db5e 100644 --- a/docs/api/qiskit/dev/pulse.mdx +++ b/docs/api/qiskit/dev/pulse.mdx @@ -72,7 +72,7 @@ These are all instances of the same base class: ### Instruction - + The smallest schedulable unit: a single instruction. It has a fixed duration and specified channels. Instruction initializer. @@ -165,7 +165,7 @@ All channels are children of the same abstract base class: ### Channel - + 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. @@ -220,7 +220,7 @@ These are all subtypes of the abstract base class [`AlignmentKind`](#qiskit.puls #### AlignmentKind - + An abstract class for schedule alignment. Create new context. @@ -234,7 +234,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### add\_implicit\_acquires - + Return a new schedule with implicit acquires from the measurement mapping replaced by explicit ones. @@ -257,7 +257,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### align\_measures - + 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. @@ -324,7 +324,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### block\_to\_schedule - + Convert `ScheduleBlock` to `Schedule`. **Parameters** @@ -351,7 +351,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### compress\_pulses - + Optimization pass to replace identical pulses. **Parameters** @@ -369,7 +369,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### flatten - + Flatten (inline) any called nodes into a Schedule tree with no nested children. **Parameters** @@ -391,7 +391,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### inline\_subroutines - + 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. @@ -415,7 +415,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### pad - + Pad the input Schedule with `Delay``s on all unoccupied timeslots until ``schedule.duration` or `until` if not `None`. **Parameters** @@ -441,7 +441,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### remove\_directives - + Remove directives. **Parameters** @@ -459,7 +459,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### remove\_trivial\_barriers - + Remove trivial barriers with 0 or 1 channels. **Parameters** @@ -483,7 +483,7 @@ The DAG transforms create DAG representation of input program. This can be used #### block\_to\_dag - + 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. @@ -541,7 +541,7 @@ A sequence of transformations to generate a target code. #### target\_qobj\_transform - + A basic pulse program transformation for OpenPulse API execution. **Parameters** @@ -758,7 +758,7 @@ The above is just a small taste of what is possible with the builder. See the re ### build - + Create a context manager for launching the imperative pulse builder DSL. To enter a building context and starting building a pulse program: @@ -818,7 +818,7 @@ DriveChannel(0) #### acquire\_channel - + Return `AcquireChannel` for `qubit` on the active builder backend. Examples: @@ -844,7 +844,7 @@ DriveChannel(0) #### control\_channels - + 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. @@ -879,7 +879,7 @@ DriveChannel(0) #### drive\_channel - + Return `DriveChannel` for `qubit` on the active builder backend. Examples: @@ -905,7 +905,7 @@ DriveChannel(0) #### measure\_channel - + Return `MeasureChannel` for `qubit` on the active builder backend. Examples: @@ -964,7 +964,7 @@ drive_sched.draw() #### acquire - + Acquire for a `duration` on a `channel` and store the result in a `register`. Examples: @@ -1001,7 +1001,7 @@ drive_sched.draw() #### barrier - + 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: @@ -1068,7 +1068,7 @@ drive_sched.draw() #### call - + Call the subroutine within the currently active builder context with arbitrary parameters which will be assigned to the target program. @@ -1237,7 +1237,7 @@ drive_sched.draw() #### delay - + Delay on a `channel` for a `duration`. Examples: @@ -1260,7 +1260,7 @@ drive_sched.draw() #### play - + Play a `pulse` on a `channel`. Examples: @@ -1283,7 +1283,7 @@ drive_sched.draw() #### reference - + 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. @@ -1308,7 +1308,7 @@ drive_sched.draw() #### set\_frequency - + Set the `frequency` of a pulse `channel`. Examples: @@ -1331,7 +1331,7 @@ drive_sched.draw() #### set\_phase - + Set the `phase` of a pulse `channel`. Examples: @@ -1356,7 +1356,7 @@ drive_sched.draw() #### shift\_frequency - + Shift the `frequency` of a pulse `channel`. Examples: @@ -1379,7 +1379,7 @@ drive_sched.draw() #### shift\_phase - + Shift the `phase` of a pulse `channel`. Examples: @@ -1404,7 +1404,7 @@ drive_sched.draw() #### snapshot - + Simulator snapshot. Examples: @@ -1747,7 +1747,7 @@ MemorySlot(0) #### measure - + 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"). @@ -1802,7 +1802,7 @@ MemorySlot(0) #### measure\_all - + 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. @@ -1835,7 +1835,7 @@ MemorySlot(0) #### delay\_qubits - + Insert delays on all the `channels.Channel`s that correspond to the input `qubits` at the same time. Examples: @@ -1892,7 +1892,7 @@ There are 1e-06 seconds in 4500 samples. #### active\_backend - + Get the backend of the currently active builder context. **Returns** @@ -1912,7 +1912,7 @@ There are 1e-06 seconds in 4500 samples. #### num\_qubits - + Return number of qubits in the currently active backend. Examples: @@ -1942,7 +1942,7 @@ There are 1e-06 seconds in 4500 samples. #### qubit\_channels - + Returns the set of channels associated with a qubit. Examples: @@ -1976,7 +1976,7 @@ There are 1e-06 seconds in 4500 samples. #### samples\_to\_seconds - + Obtain the time in seconds that will elapse for the input number of samples on the active backend. **Parameters** @@ -1994,7 +1994,7 @@ There are 1e-06 seconds in 4500 samples. #### seconds\_to\_samples - + Obtain the number of samples that will elapse in `seconds` on the active backend. Rounds down. @@ -2022,7 +2022,7 @@ There are 1e-06 seconds in 4500 samples. ### PulseError - + Errors raised by the pulse module. Set the error message. @@ -2030,7 +2030,7 @@ There are 1e-06 seconds in 4500 samples. ### BackendNotSet - + Raised if the builder context does not have a backend. Set the error message. @@ -2038,7 +2038,7 @@ There are 1e-06 seconds in 4500 samples. ### NoActiveBuilder - + Raised if no builder context is active. Set the error message. @@ -2046,7 +2046,7 @@ There are 1e-06 seconds in 4500 samples. ### UnassignedDurationError - + Raised if instruction duration is unassigned. Set the error message. @@ -2054,7 +2054,7 @@ There are 1e-06 seconds in 4500 samples. ### UnassignedReferenceError - + Raised if subroutine is unassigned. Set the error message. diff --git a/docs/api/qiskit/dev/qasm2.mdx b/docs/api/qiskit/dev/qasm2.mdx index a7a1f6f53c0..d9beeb203d8 100644 --- a/docs/api/qiskit/dev/qasm2.mdx +++ b/docs/api/qiskit/dev/qasm2.mdx @@ -32,7 +32,7 @@ This module contains two public functions, both of which create a [`QuantumCircu ### load - + 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** @@ -55,7 +55,7 @@ This module contains two public functions, both of which create a [`QuantumCircu ### loads - + Parse an OpenQASM 2 program from a string into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). **Parameters** @@ -85,7 +85,7 @@ You can extend the quantum components of the OpenQASM 2 language by passing an i #### CustomInstruction - + 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. @@ -123,7 +123,7 @@ Similar to other serialisation modules in Python, this module offers two public ### dump - + Dump a circuit as an OpenQASM 2 program to a file or stream. **Parameters** @@ -138,7 +138,7 @@ Similar to other serialisation modules in Python, this module offers two public ### dumps - + Export a circuit to an OpenQASM 2 program in a string. **Parameters** @@ -164,7 +164,7 @@ This module defines a generic error type that derives from [`QiskitError`](excep ### QASM2Error - + A general error raised by the OpenQASM 2 interoperation layer. Set the error message. @@ -174,7 +174,7 @@ In cases where the lexer or parser fails due to an invalid OpenQASM 2 file, the ### QASM2ParseError - + An error raised because of a failure to parse an OpenQASM 2 file. Set the error message. @@ -184,7 +184,7 @@ When the exporters fail to export a circuit, likely because it has structure tha ### QASM2ExportError - + An error raised because of a failure to convert a Qiskit object to an OpenQASM 2 form. Set the error message. diff --git a/docs/api/qiskit/dev/qasm3.mdx b/docs/api/qiskit/dev/qasm3.mdx index 5ca816a515a..835e2c3b2e2 100644 --- a/docs/api/qiskit/dev/qasm3.mdx +++ b/docs/api/qiskit/dev/qasm3.mdx @@ -26,7 +26,7 @@ The high-level functions are simply [`dump()`](#qiskit.qasm3.dump "qiskit.qasm3. ### dump - + Serialize a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") object as an OpenQASM 3 stream to file-like object. **Parameters** @@ -38,7 +38,7 @@ The high-level functions are simply [`dump()`](#qiskit.qasm3.dump "qiskit.qasm3. ### dumps - + Serialize a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") object in an OpenQASM 3 string. **Parameters** @@ -59,7 +59,7 @@ Both of these exporter functions are single-use wrappers around the main [`Expor ### Exporter - + QASM3 exporter main class. **Parameters** @@ -92,13 +92,13 @@ Both of these exporter functions are single-use wrappers around the main [`Expor #### dump - + Convert the circuit to OpenQASM 3, dumping the result to a file or text stream. #### dumps - + Convert the circuit to OpenQASM 3, returning the result as a string. @@ -107,7 +107,7 @@ All of these interfaces will raise [`QASM3ExporterError`](#qiskit.qasm3.QASM3Exp ### QASM3ExporterError - + An error raised during running the OpenQASM 3 exporter. Set the error message. @@ -119,7 +119,7 @@ The OpenQASM 3 language is still evolving as hardware capabilities improve, so t #### ExperimentalFeatures - + 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. @@ -213,7 +213,7 @@ Currently only two high-level functions are offered, as Qiskit support for impor ### load - + Load an OpenQASM 3 program from the file `filename`. **Parameters** @@ -235,7 +235,7 @@ Currently only two high-level functions are offered, as Qiskit support for impor ### loads - + Load an OpenQASM 3 program from the given string. **Parameters** @@ -259,7 +259,7 @@ Both of these two functions raise [`QASM3ImporterError`](#qiskit.qasm3.QASM3Impo ### QASM3ImporterError - + An error raised during the OpenQASM 3 importer. Set the error message. @@ -326,7 +326,7 @@ You can use the experimental interface immediately, with similar functions to th #### load\_experimental - + Load an OpenQASM 3 program from a source file into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). @@ -354,7 +354,7 @@ You can use the experimental interface immediately, with similar functions to th #### loads\_experimental - + Load an OpenQASM 3 program from a string into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). diff --git a/docs/api/qiskit/dev/qiskit.assembler.RunConfig.mdx b/docs/api/qiskit/dev/qiskit.assembler.RunConfig.mdx index b7412d055b4..45f92b892e3 100644 --- a/docs/api/qiskit/dev/qiskit.assembler.RunConfig.mdx +++ b/docs/api/qiskit/dev/qiskit.assembler.RunConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.assembler.RunConfig # RunConfig - + Bases: [`SimpleNamespace`](https://docs.python.org/3/library/types.html#types.SimpleNamespace "(in Python v3.12)") Class for Run Configuration. @@ -67,7 +67,7 @@ python_api_name: qiskit.assembler.RunConfig ### from\_dict - + Create a new RunConfig object from a dictionary. **Parameters** @@ -85,7 +85,7 @@ python_api_name: qiskit.assembler.RunConfig ### to\_dict - + Return a dictionary format representation of the RunConfig **Returns** diff --git a/docs/api/qiskit/dev/qiskit.circuit.AnnotatedOperation.mdx b/docs/api/qiskit/dev/qiskit.circuit.AnnotatedOperation.mdx index 7244e0fda91..0cf79ad85aa 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.AnnotatedOperation.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.AnnotatedOperation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.AnnotatedOperation # AnnotatedOperation - + Bases: [`Operation`](qiskit.circuit.Operation "qiskit.circuit.operation.Operation") Annotated operation. @@ -73,7 +73,7 @@ python_api_name: qiskit.circuit.AnnotatedOperation ### control - + Return the controlled version of itself. Implemented as an annotated operation, see [`AnnotatedOperation`](#qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). @@ -96,7 +96,7 @@ python_api_name: qiskit.circuit.AnnotatedOperation ### copy - + Return a copy of the [`AnnotatedOperation`](#qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). **Return type** @@ -106,7 +106,7 @@ python_api_name: qiskit.circuit.AnnotatedOperation ### inverse - + Return the inverse version of itself. Implemented as an annotated operation, see [`AnnotatedOperation`](#qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). @@ -122,7 +122,7 @@ python_api_name: qiskit.circuit.AnnotatedOperation ### power - + Raise this gate to the power of `exponent`. Implemented as an annotated operation, see [`AnnotatedOperation`](#qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). @@ -139,7 +139,7 @@ python_api_name: qiskit.circuit.AnnotatedOperation ### to\_matrix - + Return a matrix representation (allowing to construct Operator). diff --git a/docs/api/qiskit/dev/qiskit.circuit.BreakLoopOp.mdx b/docs/api/qiskit/dev/qiskit.circuit.BreakLoopOp.mdx index 941748847f5..7c82655a803 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.BreakLoopOp.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.BreakLoopOp.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.BreakLoopOp # BreakLoopOp - + Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") A circuit operation which, when encountered, jumps to the end of the nearest enclosing loop. Can only be used inside loops. @@ -120,19 +120,19 @@ python_api_name: qiskit.circuit.BreakLoopOp ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -151,7 +151,7 @@ python_api_name: qiskit.circuit.BreakLoopOp ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -161,7 +161,7 @@ python_api_name: qiskit.circuit.BreakLoopOp ### copy - + Copy of the instruction. **Parameters** @@ -179,7 +179,7 @@ python_api_name: qiskit.circuit.BreakLoopOp ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -203,13 +203,13 @@ python_api_name: qiskit.circuit.BreakLoopOp ### is\_parameterized - + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### repeat - + Creates an instruction with `self` repeated :math\`n\` times. If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. @@ -233,7 +233,7 @@ python_api_name: qiskit.circuit.BreakLoopOp ### 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. @@ -251,7 +251,7 @@ python_api_name: qiskit.circuit.BreakLoopOp ### soft\_compare - + 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** @@ -269,7 +269,7 @@ python_api_name: qiskit.circuit.BreakLoopOp ### 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. @@ -277,7 +277,7 @@ python_api_name: qiskit.circuit.BreakLoopOp ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/dev/qiskit.circuit.ContinueLoopOp.mdx b/docs/api/qiskit/dev/qiskit.circuit.ContinueLoopOp.mdx index d0478af16d8..ac09e8df6a9 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.ContinueLoopOp.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.ContinueLoopOp.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp # ContinueLoopOp - + 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 only be used inside loops. @@ -120,19 +120,19 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -151,7 +151,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -161,7 +161,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### copy - + Copy of the instruction. **Parameters** @@ -179,7 +179,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -203,13 +203,13 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### is\_parameterized - + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### repeat - + Creates an instruction with `self` repeated :math\`n\` times. If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. @@ -233,7 +233,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### 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. @@ -251,7 +251,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### soft\_compare - + 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** @@ -269,7 +269,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### 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. @@ -277,7 +277,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/dev/qiskit.circuit.ControlFlowOp.mdx b/docs/api/qiskit/dev/qiskit.circuit.ControlFlowOp.mdx index f088627569d..48125f3a555 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.ControlFlowOp.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.ControlFlowOp.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.ControlFlowOp # ControlFlowOp - + 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. @@ -139,19 +139,19 @@ python_api_name: qiskit.circuit.ControlFlowOp ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -170,7 +170,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -180,7 +180,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### copy - + Copy of the instruction. **Parameters** @@ -198,7 +198,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -222,13 +222,13 @@ python_api_name: qiskit.circuit.ControlFlowOp ### is\_parameterized - + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### iter\_captured\_vars - + Get an iterator over the unique captured variables in all blocks of this construct. **Return type** @@ -238,7 +238,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### repeat - + Creates an instruction with `self` repeated :math\`n\` times. If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. @@ -262,7 +262,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### replace\_blocks - + Return a new version of this control-flow operations with the [`blocks`](#qiskit.circuit.ControlFlowOp.blocks "qiskit.circuit.ControlFlowOp.blocks") mapped to the given new ones. Typically this is used in a workflow such as: @@ -297,7 +297,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### 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. @@ -315,7 +315,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### soft\_compare - + 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** @@ -333,7 +333,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### 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. @@ -341,7 +341,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/dev/qiskit.circuit.ControlledGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.ControlledGate.mdx index bdfb54dda22..172d9a3d687 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.ControlledGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.ControlledGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.ControlledGate # ControlledGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Controlled unitary gate. @@ -203,19 +203,19 @@ python_api_name: qiskit.circuit.ControlledGate ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + 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: @@ -268,7 +268,7 @@ python_api_name: qiskit.circuit.ControlledGate ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -278,7 +278,7 @@ python_api_name: qiskit.circuit.ControlledGate ### control - + Return the controlled version of itself. Implemented either as a controlled gate (ref. [`ControlledGate`](#qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). @@ -301,7 +301,7 @@ python_api_name: qiskit.circuit.ControlledGate ### copy - + Copy of the instruction. **Parameters** @@ -319,7 +319,7 @@ python_api_name: qiskit.circuit.ControlledGate ### inverse - + Invert this gate by calling inverse on the base gate. **Return type** @@ -329,13 +329,13 @@ python_api_name: qiskit.circuit.ControlledGate ### is\_parameterized - + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. @@ -356,7 +356,7 @@ python_api_name: qiskit.circuit.ControlledGate ### repeat - + Creates an instruction with `self` repeated :math\`n\` times. If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. @@ -380,7 +380,7 @@ python_api_name: qiskit.circuit.ControlledGate ### 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. @@ -398,7 +398,7 @@ python_api_name: qiskit.circuit.ControlledGate ### soft\_compare - + 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** @@ -416,7 +416,7 @@ python_api_name: qiskit.circuit.ControlledGate ### to\_matrix - + Return a Numpy.array for the gate unitary matrix. **Returns** @@ -434,7 +434,7 @@ python_api_name: qiskit.circuit.ControlledGate ### 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. @@ -442,7 +442,7 @@ python_api_name: qiskit.circuit.ControlledGate ### validate\_parameter - + Gate parameters should be int, float, or ParameterExpression diff --git a/docs/api/qiskit/dev/qiskit.circuit.EquivalenceLibrary.mdx b/docs/api/qiskit/dev/qiskit.circuit.EquivalenceLibrary.mdx index a9feae0eb98..9d46ec616e3 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.EquivalenceLibrary.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.EquivalenceLibrary.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary # EquivalenceLibrary - + 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. @@ -41,7 +41,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary ### add\_equivalence - + 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. @@ -54,7 +54,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary ### draw - + Draws the equivalence relations available in the library. **Parameters** @@ -78,7 +78,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary ### get\_entry - + 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. @@ -102,7 +102,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary ### has\_entry - + Check if a library contains any decompositions for gate. **Parameters** @@ -122,7 +122,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary ### keys - + Return list of keys to key to node index map. **Returns** @@ -136,7 +136,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary ### node\_index - + Return node index for a given key. **Parameters** @@ -154,7 +154,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary ### set\_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. diff --git a/docs/api/qiskit/dev/qiskit.circuit.ForLoopOp.mdx b/docs/api/qiskit/dev/qiskit.circuit.ForLoopOp.mdx index d4452a25b0b..fe00b5c9add 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.ForLoopOp.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.ForLoopOp.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.ForLoopOp # ForLoopOp - + 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`. @@ -123,19 +123,19 @@ python_api_name: qiskit.circuit.ForLoopOp ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -154,7 +154,7 @@ python_api_name: qiskit.circuit.ForLoopOp ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -164,7 +164,7 @@ python_api_name: qiskit.circuit.ForLoopOp ### copy - + Copy of the instruction. **Parameters** @@ -182,7 +182,7 @@ python_api_name: qiskit.circuit.ForLoopOp ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -206,13 +206,13 @@ python_api_name: qiskit.circuit.ForLoopOp ### is\_parameterized - + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### iter\_captured\_vars - + Get an iterator over the unique captured variables in all blocks of this construct. **Return type** @@ -222,7 +222,7 @@ python_api_name: qiskit.circuit.ForLoopOp ### repeat - + Creates an instruction with `self` repeated :math\`n\` times. If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. @@ -246,7 +246,7 @@ python_api_name: qiskit.circuit.ForLoopOp ### replace\_blocks - + Return a new version of this control-flow operations with the [`blocks`](#qiskit.circuit.ForLoopOp.blocks "qiskit.circuit.ForLoopOp.blocks") mapped to the given new ones. Typically this is used in a workflow such as: @@ -277,7 +277,7 @@ python_api_name: qiskit.circuit.ForLoopOp ### 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. @@ -295,7 +295,7 @@ python_api_name: qiskit.circuit.ForLoopOp ### soft\_compare - + 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** @@ -313,7 +313,7 @@ python_api_name: qiskit.circuit.ForLoopOp ### 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. @@ -321,7 +321,7 @@ python_api_name: qiskit.circuit.ForLoopOp ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/dev/qiskit.circuit.Gate.mdx b/docs/api/qiskit/dev/qiskit.circuit.Gate.mdx index e2e862bc4f9..a9713afdaa5 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.Gate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.Gate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.Gate # Gate - + Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") Unitary gate. @@ -123,19 +123,19 @@ python_api_name: qiskit.circuit.Gate ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + 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: @@ -188,7 +188,7 @@ python_api_name: qiskit.circuit.Gate ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -198,7 +198,7 @@ python_api_name: qiskit.circuit.Gate ### control - + Return the controlled version of itself. Implemented either as a controlled gate (ref. [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). @@ -221,7 +221,7 @@ python_api_name: qiskit.circuit.Gate ### copy - + Copy of the instruction. **Parameters** @@ -239,7 +239,7 @@ python_api_name: qiskit.circuit.Gate ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -263,13 +263,13 @@ python_api_name: qiskit.circuit.Gate ### is\_parameterized - + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. @@ -290,7 +290,7 @@ python_api_name: qiskit.circuit.Gate ### repeat - + Creates an instruction with `self` repeated :math\`n\` times. If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. @@ -314,7 +314,7 @@ python_api_name: qiskit.circuit.Gate ### 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. @@ -332,7 +332,7 @@ python_api_name: qiskit.circuit.Gate ### soft\_compare - + 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** @@ -350,7 +350,7 @@ python_api_name: qiskit.circuit.Gate ### to\_matrix - + Return a Numpy.array for the gate unitary matrix. **Returns** @@ -368,7 +368,7 @@ python_api_name: qiskit.circuit.Gate ### 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. @@ -376,7 +376,7 @@ python_api_name: qiskit.circuit.Gate ### validate\_parameter - + Gate parameters should be int, float, or ParameterExpression diff --git a/docs/api/qiskit/dev/qiskit.circuit.IfElseOp.mdx b/docs/api/qiskit/dev/qiskit.circuit.IfElseOp.mdx index 024a87d23fb..f6553e17cd0 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.IfElseOp.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.IfElseOp.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.IfElseOp # IfElseOp - + 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. @@ -127,19 +127,19 @@ python_api_name: qiskit.circuit.IfElseOp ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -158,7 +158,7 @@ python_api_name: qiskit.circuit.IfElseOp ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -168,7 +168,7 @@ python_api_name: qiskit.circuit.IfElseOp ### copy - + Copy of the instruction. **Parameters** @@ -186,7 +186,7 @@ python_api_name: qiskit.circuit.IfElseOp ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -210,13 +210,13 @@ python_api_name: qiskit.circuit.IfElseOp ### is\_parameterized - + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### iter\_captured\_vars - + Get an iterator over the unique captured variables in all blocks of this construct. **Return type** @@ -226,7 +226,7 @@ python_api_name: qiskit.circuit.IfElseOp ### repeat - + Creates an instruction with `self` repeated :math\`n\` times. If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. @@ -250,7 +250,7 @@ python_api_name: qiskit.circuit.IfElseOp ### replace\_blocks - + Replace blocks and return new instruction. **Parameters** @@ -268,7 +268,7 @@ python_api_name: qiskit.circuit.IfElseOp ### 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. @@ -286,7 +286,7 @@ python_api_name: qiskit.circuit.IfElseOp ### soft\_compare - + 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** @@ -304,7 +304,7 @@ python_api_name: qiskit.circuit.IfElseOp ### 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. @@ -312,7 +312,7 @@ python_api_name: qiskit.circuit.IfElseOp ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/dev/qiskit.circuit.Instruction.mdx b/docs/api/qiskit/dev/qiskit.circuit.Instruction.mdx index 51caea613a1..f8a8c6acfb0 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.Instruction.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.Instruction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.Instruction # Instruction - + Bases: [`Operation`](qiskit.circuit.Operation "qiskit.circuit.operation.Operation") Generic quantum instruction. @@ -131,19 +131,19 @@ python_api_name: qiskit.circuit.Instruction ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -162,7 +162,7 @@ python_api_name: qiskit.circuit.Instruction ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -172,7 +172,7 @@ python_api_name: qiskit.circuit.Instruction ### copy - + Copy of the instruction. **Parameters** @@ -190,7 +190,7 @@ python_api_name: qiskit.circuit.Instruction ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -214,13 +214,13 @@ python_api_name: qiskit.circuit.Instruction ### is\_parameterized - + Return whether the [`Instruction`](#qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### repeat - + Creates an instruction with `self` repeated :math\`n\` times. If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. @@ -244,7 +244,7 @@ python_api_name: qiskit.circuit.Instruction ### 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. @@ -262,7 +262,7 @@ python_api_name: qiskit.circuit.Instruction ### soft\_compare - + 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** @@ -280,7 +280,7 @@ python_api_name: qiskit.circuit.Instruction ### 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. @@ -288,7 +288,7 @@ python_api_name: qiskit.circuit.Instruction ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/dev/qiskit.circuit.InstructionSet.mdx b/docs/api/qiskit/dev/qiskit.circuit.InstructionSet.mdx index c227279a4aa..43b59b663ec 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.InstructionSet.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.InstructionSet.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.InstructionSet # InstructionSet - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Instruction collection, and their contexts. @@ -51,13 +51,13 @@ python_api_name: qiskit.circuit.InstructionSet ### add - + Add an instruction and its context (where it is attached). ### c\_if - + Set a classical equality condition on all the instructions in this set between the [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") or [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") `classical` and value `val`. @@ -88,7 +88,7 @@ python_api_name: qiskit.circuit.InstructionSet ### inverse - + Invert all instructions. diff --git a/docs/api/qiskit/dev/qiskit.circuit.Operation.mdx b/docs/api/qiskit/dev/qiskit.circuit.Operation.mdx index 98d23603082..fea95704913 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.Operation.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.Operation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.Operation # Operation - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Quantum operation interface. diff --git a/docs/api/qiskit/dev/qiskit.circuit.Parameter.mdx b/docs/api/qiskit/dev/qiskit.circuit.Parameter.mdx index bae96e6ea82..9c5d7efacb2 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.Parameter.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.Parameter.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.Parameter # Parameter - + Bases: [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") A compile-time symbolic parameter. @@ -73,31 +73,31 @@ python_api_name: qiskit.circuit.Parameter ### abs - + Absolute of a ParameterExpression ### arccos - + Arccos of a ParameterExpression ### arcsin - + Arcsin of a ParameterExpression ### arctan - + Arctan of a ParameterExpression ### assign - + Assign one parameter to a value, which can either be numeric or another parameter expression. **Parameters** @@ -112,7 +112,7 @@ python_api_name: qiskit.circuit.Parameter ### bind - + Binds the provided set of parameters to their corresponding values. **Parameters** @@ -141,7 +141,7 @@ python_api_name: qiskit.circuit.Parameter ### conjugate - + Return the conjugate. **Return type** @@ -151,19 +151,19 @@ python_api_name: qiskit.circuit.Parameter ### cos - + Cosine of a ParameterExpression ### exp - + Exponential of a ParameterExpression ### gradient - + Get the derivative of a parameter expression w\.r.t. a specified parameter expression. **Parameters** @@ -181,19 +181,19 @@ python_api_name: qiskit.circuit.Parameter ### is\_real - + Return whether the expression is real ### log - + Logarithm of a ParameterExpression ### numeric - + Return a Python number representing this object, using the most restrictive of [`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)") and [`complex`](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") that is valid for this object. In general, an [`int`](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") is only returned if the expression only involved symbolic integers. If floating-point values were used during the evaluation, the return value will be a [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") regardless of whether the represented value is an integer. This is because floating-point values “infect” symbolic computations by their inexact nature, and symbolic libraries will use inexact floating-point semantics not exact real-number semantics when they are involved. If you want to assert that all floating-point calculations *were* carried out at infinite precision (i.e. [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") could represent every intermediate value exactly), you can use [`float.is_integer()`](https://docs.python.org/3/library/stdtypes.html#float.is_integer "(in Python v3.12)") to check if the return float represents an integer and cast it using [`int`](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") if so. This would be an unusual pattern; typically one requires this by only ever using explicitly [`Rational`](https://docs.python.org/3/library/numbers.html#numbers.Rational "(in Python v3.12)") objects while working with symbolic expressions. @@ -215,25 +215,25 @@ python_api_name: qiskit.circuit.Parameter ### sign - + Sign of a ParameterExpression ### sin - + Sine of a ParameterExpression ### subs - + Substitute self with the corresponding parameter in `parameter_map`. ### 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. @@ -245,7 +245,7 @@ python_api_name: qiskit.circuit.Parameter ### tan - + Tangent of a ParameterExpression diff --git a/docs/api/qiskit/dev/qiskit.circuit.ParameterExpression.mdx b/docs/api/qiskit/dev/qiskit.circuit.ParameterExpression.mdx index 1395c9d5eec..538cfa9035e 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.ParameterExpression.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.ParameterExpression.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.ParameterExpression # ParameterExpression - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") ParameterExpression class to enable creating expressions of Parameters. @@ -34,31 +34,31 @@ python_api_name: qiskit.circuit.ParameterExpression ### abs - + Absolute of a ParameterExpression ### arccos - + Arccos of a ParameterExpression ### arcsin - + Arcsin of a ParameterExpression ### arctan - + Arctan of a ParameterExpression ### assign - + Assign one parameter to a value, which can either be numeric or another parameter expression. **Parameters** @@ -77,7 +77,7 @@ python_api_name: qiskit.circuit.ParameterExpression ### bind - + Binds the provided set of parameters to their corresponding values. **Parameters** @@ -106,7 +106,7 @@ python_api_name: qiskit.circuit.ParameterExpression ### conjugate - + Return the conjugate. **Return type** @@ -116,19 +116,19 @@ python_api_name: qiskit.circuit.ParameterExpression ### cos - + Cosine of a ParameterExpression ### exp - + Exponential of a ParameterExpression ### gradient - + Get the derivative of a parameter expression w\.r.t. a specified parameter expression. **Parameters** @@ -146,19 +146,19 @@ python_api_name: qiskit.circuit.ParameterExpression ### is\_real - + Return whether the expression is real ### log - + Logarithm of a ParameterExpression ### numeric - + Return a Python number representing this object, using the most restrictive of [`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)") and [`complex`](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") that is valid for this object. In general, an [`int`](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") is only returned if the expression only involved symbolic integers. If floating-point values were used during the evaluation, the return value will be a [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") regardless of whether the represented value is an integer. This is because floating-point values “infect” symbolic computations by their inexact nature, and symbolic libraries will use inexact floating-point semantics not exact real-number semantics when they are involved. If you want to assert that all floating-point calculations *were* carried out at infinite precision (i.e. [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") could represent every intermediate value exactly), you can use [`float.is_integer()`](https://docs.python.org/3/library/stdtypes.html#float.is_integer "(in Python v3.12)") to check if the return float represents an integer and cast it using [`int`](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") if so. This would be an unusual pattern; typically one requires this by only ever using explicitly [`Rational`](https://docs.python.org/3/library/numbers.html#numbers.Rational "(in Python v3.12)") objects while working with symbolic expressions. @@ -180,19 +180,19 @@ python_api_name: qiskit.circuit.ParameterExpression ### sign - + Sign of a ParameterExpression ### sin - + Sine of a ParameterExpression ### subs - + Returns a new Expression with replacement Parameters. **Parameters** @@ -217,7 +217,7 @@ python_api_name: qiskit.circuit.ParameterExpression ### 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. @@ -229,7 +229,7 @@ python_api_name: qiskit.circuit.ParameterExpression ### tan - + Tangent of a ParameterExpression diff --git a/docs/api/qiskit/dev/qiskit.circuit.ParameterVector.mdx b/docs/api/qiskit/dev/qiskit.circuit.ParameterVector.mdx index 40a1916f100..4f22b2ba7a8 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.ParameterVector.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.ParameterVector.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.ParameterVector # ParameterVector - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") ParameterVector class to quickly generate lists of parameters. @@ -31,13 +31,13 @@ python_api_name: qiskit.circuit.ParameterVector ### index - + Returns first index of value. ### resize - + 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/dev/qiskit.circuit.QuantumCircuit.mdx b/docs/api/qiskit/dev/qiskit.circuit.QuantumCircuit.mdx index ad38aab0eb8..e4e81b9e019 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.QuantumCircuit.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.QuantumCircuit.mdx @@ -6,117 +6,190 @@ python_api_type: class python_api_name: qiskit.circuit.QuantumCircuit --- -# QuantumCircuit + + + + +# [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") class + + + Core Qiskit representation of a quantum circuit. + + + For more details setting the [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") in context of all of the data structures that go with it, how it fits into the rest of the [`qiskit`](index#module-qiskit "qiskit") package, and the different regimes of quantum-circuit descriptions in Qiskit, see the module-level documentation of [`qiskit.circuit`](circuit#module-qiskit.circuit "qiskit.circuit"). + + + ## Circuit attributes + + [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") has a small number of public attributes, which are mostly older functionality. Most of its functionality is accessed through methods. + + A small handful of the attributes are intentionally mutable, the rest are data attributes that should be considered immutable. + + | Mutable attribute | Summary | + | ---------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------- | + | [`global_phase`](#qiskit.circuit.QuantumCircuit.global_phase "qiskit.circuit.QuantumCircuit.global_phase") | The global phase of the circuit, measured in radians. | + | [`metadata`](#qiskit.circuit.QuantumCircuit.metadata "qiskit.circuit.QuantumCircuit.metadata") | Arbitrary user mapping, which Qiskit will preserve through the transpiler, but otherwise completely ignore. | + | [`name`](#qiskit.circuit.QuantumCircuit.name "qiskit.circuit.QuantumCircuit.name") | An optional string name for the circuit. | + + | Immutable data attribute | Summary | + | ------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------- | + | [`ancillas`](#qiskit.circuit.QuantumCircuit.ancillas "qiskit.circuit.QuantumCircuit.ancillas") | List of [`AncillaQubit`](circuit#qiskit.circuit.AncillaQubit "qiskit.circuit.AncillaQubit")s tracked by the circuit. | + | [`calibrations`](#qiskit.circuit.QuantumCircuit.calibrations "qiskit.circuit.QuantumCircuit.calibrations") | Custom user-supplied pulse calibrations for individual instructions. | + | [`cregs`](#qiskit.circuit.QuantumCircuit.cregs "qiskit.circuit.QuantumCircuit.cregs") | List of [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")s tracked by the circuit. | + | [`clbits`](#qiskit.circuit.QuantumCircuit.clbits "qiskit.circuit.QuantumCircuit.clbits") | List of [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit")s tracked by the circuit. | + | [`data`](#qiskit.circuit.QuantumCircuit.data "qiskit.circuit.QuantumCircuit.data") | List of individual [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s that make up the circuit. | + | [`duration`](#qiskit.circuit.QuantumCircuit.duration "qiskit.circuit.QuantumCircuit.duration") | Total duration of the circuit, added by scheduling transpiler passes. | + | [`layout`](#qiskit.circuit.QuantumCircuit.layout "qiskit.circuit.QuantumCircuit.layout") | Hardware layout and routing information added by the transpiler. | + | [`num_ancillas`](#qiskit.circuit.QuantumCircuit.num_ancillas "qiskit.circuit.QuantumCircuit.num_ancillas") | The number of ancilla qubits in the circuit. | + | [`num_clbits`](#qiskit.circuit.QuantumCircuit.num_clbits "qiskit.circuit.QuantumCircuit.num_clbits") | The number of clbits in the circuit. | + | [`num_captured_vars`](#qiskit.circuit.QuantumCircuit.num_captured_vars "qiskit.circuit.QuantumCircuit.num_captured_vars") | Number of captured real-time classical variables. | + | [`num_declared_vars`](#qiskit.circuit.QuantumCircuit.num_declared_vars "qiskit.circuit.QuantumCircuit.num_declared_vars") | Number of locally declared real-time classical variables in the outer circuit scope. | + | [`num_input_vars`](#qiskit.circuit.QuantumCircuit.num_input_vars "qiskit.circuit.QuantumCircuit.num_input_vars") | Number of input real-time classical variables. | + | [`num_parameters`](#qiskit.circuit.QuantumCircuit.num_parameters "qiskit.circuit.QuantumCircuit.num_parameters") | Number of compile-time [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")s in the circuit. | + | [`num_qubits`](#qiskit.circuit.QuantumCircuit.num_qubits "qiskit.circuit.QuantumCircuit.num_qubits") | Number of qubits in the circuit. | + | [`num_vars`](#qiskit.circuit.QuantumCircuit.num_vars "qiskit.circuit.QuantumCircuit.num_vars") | Total number of real-time classical variables in the outer circuit scope. | + | [`op_start_times`](#qiskit.circuit.QuantumCircuit.op_start_times "qiskit.circuit.QuantumCircuit.op_start_times") | Start times of scheduled operations, added by scheduling transpiler passes. | + | [`parameters`](#qiskit.circuit.QuantumCircuit.parameters "qiskit.circuit.QuantumCircuit.parameters") | Ordered set-like view of the compile-time [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")s tracked by the circuit. | + | [`qregs`](#qiskit.circuit.QuantumCircuit.qregs "qiskit.circuit.QuantumCircuit.qregs") | List of [`QuantumRegister`](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister")s tracked by the circuit. | + | [`qubits`](#qiskit.circuit.QuantumCircuit.qubits "qiskit.circuit.QuantumCircuit.qubits") | List of [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")s tracked by the circuit. | + | [`unit`](#qiskit.circuit.QuantumCircuit.unit "qiskit.circuit.QuantumCircuit.unit") | The unit of the [`duration`](#qiskit.circuit.QuantumCircuit.duration "qiskit.circuit.QuantumCircuit.duration") field. | + + The core attribute is [`data`](#qiskit.circuit.QuantumCircuit.data "qiskit.circuit.QuantumCircuit.data"). This is a sequence-like object that exposes the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s contained in an ordered form. You generally should not mutate this object directly; [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") is only designed for append-only operations (which should use [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append")). Most operations that mutate circuits in place should be written as transpiler passes ([`qiskit.transpiler`](transpiler#module-qiskit.transpiler "qiskit.transpiler")). - - Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + ### data - Create a new circuit. + + The circuit data (instructions and context). - A circuit is a list of instructions bound to some registers. + **Returns** - **Parameters** + a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. - * **regs** (list([`Register`](circuit#qiskit.circuit.Register "qiskit.circuit.Register")) or list(`int`) or list(list([`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit")))) – + **Return type** - The registers to be included in the circuit. + QuantumCircuitData + - * If a list of [`Register`](circuit#qiskit.circuit.Register "qiskit.circuit.Register") objects, represents the [`QuantumRegister`](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") and/or [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") objects to include in the circuit. + Alongside the [`data`](#qiskit.circuit.QuantumCircuit.data "qiskit.circuit.QuantumCircuit.data"), the [`global_phase`](#qiskit.circuit.QuantumCircuit.global_phase "qiskit.circuit.QuantumCircuit.global_phase") of a circuit can have some impact on its output, if the circuit is used to describe a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") that may be controlled. This is measured in radians and is directly settable. - For example: + ### global\_phase - > * `QuantumCircuit(QuantumRegister(4))` - > * `QuantumCircuit(QuantumRegister(4), ClassicalRegister(3))` - > * `QuantumCircuit(QuantumRegister(4, 'qr0'), QuantumRegister(2, 'qr1'))` + + The global phase of the current circuit scope in radians. + - * 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. + The [`name`](#qiskit.circuit.QuantumCircuit.name "qiskit.circuit.QuantumCircuit.name") of a circuit becomes the name of the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") or [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") resulting from [`to_instruction()`](#qiskit.circuit.QuantumCircuit.to_instruction "qiskit.circuit.QuantumCircuit.to_instruction") and [`to_gate()`](#qiskit.circuit.QuantumCircuit.to_gate "qiskit.circuit.QuantumCircuit.to_gate") calls, which can be handy for visualizations. - For example: + ### name - > * `QuantumCircuit(4) # A QuantumCircuit with 4 qubits` - > * `QuantumCircuit(4, 3) # A QuantumCircuit with 4 qubits and 3 classical bits` + + A human-readable name for the circuit. + - * If a list of python lists containing [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") objects, a collection of [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") s to be added to the circuit. + You can attach arbitrary [`metadata`](#qiskit.circuit.QuantumCircuit.metadata "qiskit.circuit.QuantumCircuit.metadata") to a circuit. No part of core Qiskit will inspect this or change its behavior based on metadata, but it will be faithfully passed through the transpiler, so you can tag your circuits yourself. When serializing a circuit with QPY (see [`qiskit.qpy`](qpy#module-qiskit.qpy "qiskit.qpy")), the metadata will be JSON-serialized and you may need to pass a custom serializer to handle non-JSON-compatible objects within it (see [`qpy.dump()`](qpy#qiskit.qpy.dump "qiskit.qpy.dump") for more detail). This field is ignored during export to OpenQASM 2 or 3. - * **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. + ### metadata - * **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. + + Arbitrary user-defined metadata for the circuit. - * **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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. + - * **inputs** (*Iterable\[*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")*]*) – any variables to declare as `input` real-time variables for this circuit. These should already be existing [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes that you build from somewhere else; if you need to create the inputs as well, use [`QuantumCircuit.add_input()`](#qiskit.circuit.QuantumCircuit.add_input "qiskit.circuit.QuantumCircuit.add_input"). The variables given in this argument will be passed directly to [`add_input()`](#qiskit.circuit.QuantumCircuit.add_input "qiskit.circuit.QuantumCircuit.add_input"). A circuit cannot have both `inputs` and `captures`. + [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") exposes data attributes tracking its internal quantum and classical bits and registers. These appear as Python [`list`](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")s, but you should treat them as immutable; changing them will *at best* have no effect, and more likely will simply corrupt the internal data of the [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). - * **captures** (*Iterable\[*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")*]*) – any variables that that this circuit scope should capture from a containing scope. The variables given here will be passed directly to [`add_capture()`](#qiskit.circuit.QuantumCircuit.add_capture "qiskit.circuit.QuantumCircuit.add_capture"). A circuit cannot have both `inputs` and `captures`. + ### qregs - * **declarations** (*Mapping\[*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")*,* [*expr.Expr*](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")*] | Iterable\[Tuple\[*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")*,* [*expr.Expr*](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")*]]*) – + + A list of the [`QuantumRegister`](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister")s in this circuit. You should not mutate this. + - any variables that this circuit should declare and initialize immediately. You can order this input so that later declarations depend on earlier ones (including inputs or captures). If you need to depend on values that will be computed later at runtime, use [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var") at an appropriate point in the circuit execution. + ### cregs - This argument is intended for convenient circuit initialization when you already have a set of created variables. The variables used here will be directly passed to [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var"), which you can use directly if this is the first time you are creating the variable. + + A list of the [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")s in this circuit. You should not mutate this. + - **Raises** + ### qubits - * [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the circuit name, if given, is not valid. - * [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if both `inputs` and `captures` are given. + + A list of [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")s in the order that they were added. You should not mutate this. + - **Examples** + ### ancillas - Construct a simple Bell state circuit. + + A list of [`AncillaQubit`](circuit#qiskit.circuit.AncillaQubit "qiskit.circuit.AncillaQubit")s in the order that they were added. You should not mutate this. + - ```python - from qiskit import QuantumCircuit + ### clbits - qc = QuantumCircuit(2, 2) - qc.h(0) - qc.cx(0, 1) - qc.measure([0, 1], [0, 1]) - qc.draw('mpl') - ``` + + A list of [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit")s in the order that they were added. You should not mutate this. + - ![../\_images/qiskit-circuit-QuantumCircuit-1.png](/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-1.png) + The [compile-time parameters](circuit#circuit-compile-time-parameters) present in instructions on the circuit are available in [`parameters`](#qiskit.circuit.QuantumCircuit.parameters "qiskit.circuit.QuantumCircuit.parameters"). This has a canonical order (mostly lexical, except in the case of [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector")), which matches the order that parameters will be assigned when using the list forms of [`assign_parameters()`](#qiskit.circuit.QuantumCircuit.assign_parameters "qiskit.circuit.QuantumCircuit.assign_parameters"), but also supports [`set`](https://docs.python.org/3/library/stdtypes.html#set "(in Python v3.12)")-like constant-time membership testing. - Construct a 5-qubit GHZ circuit. + ### parameters - ```python - from qiskit import QuantumCircuit + + The parameters defined in the circuit. - qc = QuantumCircuit(5) - qc.h(0) - qc.cx(0, range(1, 5)) - qc.measure_all() - ``` + 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. - Construct a 4-qubit Bernstein-Vazirani circuit using registers. + **Examples** - ```python - from qiskit import QuantumRegister, ClassicalRegister, QuantumCircuit + The snippet below shows that insertion order of parameters does not matter. - qr = QuantumRegister(3, 'q') - anc = QuantumRegister(1, 'ancilla') - cr = ClassicalRegister(3, 'c') - qc = QuantumCircuit(qr, anc, cr) + ```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)]) + ``` - 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) + Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. - qc.draw('mpl') - ``` + ```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)]) + ``` - ![../\_images/qiskit-circuit-QuantumCircuit-2.png](/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-2.png) + To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. - ## Attributes + ```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]) + ]) + ``` - ### ancillas + **Returns** - - Returns a list of ancilla bits in the order that the registers were added. + The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + The storage of any [manual pulse-level calibrations](#circuit-calibrations) for individual instructions on the circuit is in [`calibrations`](#qiskit.circuit.QuantumCircuit.calibrations "qiskit.circuit.QuantumCircuit.calibrations"). This presents as a [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)"), but should not be mutated directly; use the methods discussed in [Manual calibration of instructions](#circuit-calibrations). + ### calibrations @@ -125,60 +198,62 @@ python_api_name: qiskit.circuit.QuantumCircuit The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` - ### clbits + If you have transpiled your circuit, so you have a physical circuit, you can inspect the [`layout`](#qiskit.circuit.QuantumCircuit.layout "qiskit.circuit.QuantumCircuit.layout") attribute for information stored by the transpiler about how the virtual qubits of the source circuit map to the hardware qubits of your physical circuit, both at the start and end of the circuit. - - Returns a list of classical bits in the order that the registers were added. - + ### layout - ### data + + Return any associated layout information about the circuit - - Return the circuit data (instructions and context). + 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. - **Returns** + 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. + - a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + If your circuit was also *scheduled* as part of a transpilation, it will expose the individual timings of each instruction, along with the total [`duration`](#qiskit.circuit.QuantumCircuit.duration "qiskit.circuit.QuantumCircuit.duration") of the circuit. - **Return type** + ### duration - QuantumCircuitData + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.QuantumCircuit.unit "qiskit.circuit.QuantumCircuit.unit"). - ### global\_phase + ### unit - - Return the global phase of the current circuit scope in radians. + + The unit that [`duration`](#qiskit.circuit.QuantumCircuit.duration "qiskit.circuit.QuantumCircuit.duration") is specified in. - ### instances - - - - ### layout + ### op\_start\_times - - Return any associated layout information about the circuit + + Return a list of operation start times. - 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. + This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. - 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. - + **Returns** - ### metadata + 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"). - - The user provided metadata associated with the circuit. + **Raises** - 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. + [**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + Finally, [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") exposes several simple properties as dynamic read-only numeric attributes. + ### num\_ancillas Return the number of ancilla qubits. + ### num\_clbits + + + Return number of classical bits. + + ### num\_captured\_vars @@ -187,12 +262,6 @@ python_api_name: qiskit.circuit.QuantumCircuit This is the length of the [`iter_captured_vars()`](#qiskit.circuit.QuantumCircuit.iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars") iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.QuantumCircuit.num_input_vars "qiskit.circuit.QuantumCircuit.num_input_vars") must be zero. - ### num\_clbits - - - Return number of classical bits. - - ### num\_declared\_vars @@ -229,179 +298,245 @@ python_api_name: qiskit.circuit.QuantumCircuit This is the length of the [`iter_vars()`](#qiskit.circuit.QuantumCircuit.iter_vars "qiskit.circuit.QuantumCircuit.iter_vars") iterable. - ### op\_start\_times - - - Return a list of operation start times. + ## Creating new circuits - This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + | Method | Summary | + | --------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------- | + | [`__init__()`](#qiskit.circuit.QuantumCircuit.__init__ "qiskit.circuit.QuantumCircuit.__init__") | Default constructor of no-instruction circuits. | + | [`copy()`](#qiskit.circuit.QuantumCircuit.copy "qiskit.circuit.QuantumCircuit.copy") | Make a complete copy of an existing circuit. | + | [`copy_empty_like()`](#qiskit.circuit.QuantumCircuit.copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like") | Copy data objects from one circuit into a new one without any instructions. | + | [`from_instructions()`](#qiskit.circuit.QuantumCircuit.from_instructions "qiskit.circuit.QuantumCircuit.from_instructions") | Infer data objects needed from a list of instructions. | + | [`from_qasm_file()`](#qiskit.circuit.QuantumCircuit.from_qasm_file "qiskit.circuit.QuantumCircuit.from_qasm_file") | Legacy interface to [`qasm2.load()`](qasm2#qiskit.qasm2.load "qiskit.qasm2.load"). | + | [`from_qasm_str()`](#qiskit.circuit.QuantumCircuit.from_qasm_str "qiskit.circuit.QuantumCircuit.from_qasm_str") | Legacy interface to [`qasm2.loads()`](qasm2#qiskit.qasm2.loads "qiskit.qasm2.loads"). | - **Returns** + The default constructor (`QuantumCircuit(...)`) produces a circuit with no initial instructions. The arguments to the default constructor can be used to seed the circuit with quantum and classical data storage, and to provide a name, global phase and arbitrary metadata. All of these fields can be expanded later. - 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"). + ### \_\_init\_\_ - **Raises** + + Default constructor of [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). - [**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. - + **Parameters** - ### parameters + * **regs** ([*Register*](circuit#qiskit.circuit.Register "qiskit.circuit.Register") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| Sequence\[*[*Bit*](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit")*]*) – - - The parameters defined in the circuit. + The registers to be included 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. + * If a list of [`Register`](circuit#qiskit.circuit.Register "qiskit.circuit.Register") objects, represents the [`QuantumRegister`](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") and/or [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") objects to include in the circuit. - **Examples** + For example: - The snippet below shows that insertion order of parameters does not matter. + > * `QuantumCircuit(QuantumRegister(4))` + > * `QuantumCircuit(QuantumRegister(4), ClassicalRegister(3))` + > * `QuantumCircuit(QuantumRegister(4, 'qr0'), QuantumRegister(2, 'qr1'))` - ```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)]) - ``` + * 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. - Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + For example: - ```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)]) - ``` + > * `QuantumCircuit(4) # A QuantumCircuit with 4 qubits` + > * `QuantumCircuit(4, 3) # A QuantumCircuit with 4 qubits and 3 classical bits` - To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + * If a list of python lists containing [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") objects, a collection of [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") s to be added to the circuit. - ```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]) - ]) - ``` + * **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – the name of the quantum circuit. If not set, an automatically generated string will be assigned. - **Returns** + * **global\_phase** (*ParameterValueType*) – The global phase of the circuit in radians. - The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. - + * **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. 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. - ### prefix + * **inputs** (*Iterable\[*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")*]*) – any variables to declare as `input` runtime variables for this circuit. These should already be existing [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes that you build from somewhere else; if you need to create the inputs as well, use [`QuantumCircuit.add_input()`](#qiskit.circuit.QuantumCircuit.add_input "qiskit.circuit.QuantumCircuit.add_input"). The variables given in this argument will be passed directly to [`add_input()`](#qiskit.circuit.QuantumCircuit.add_input "qiskit.circuit.QuantumCircuit.add_input"). A circuit cannot have both `inputs` and `captures`. - + * **captures** (*Iterable\[*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")*]*) – any variables that that this circuit scope should capture from a containing scope. The variables given here will be passed directly to [`add_capture()`](#qiskit.circuit.QuantumCircuit.add_capture "qiskit.circuit.QuantumCircuit.add_capture"). A circuit cannot have both `inputs` and `captures`. - ### qubits + * **declarations** (*Mapping\[*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")*,* [*expr.Expr*](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")*] | Iterable\[Tuple\[*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")*,* [*expr.Expr*](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")*]]*) – - - Returns a list of quantum bits in the order that the registers were added. - + any variables that this circuit should declare and initialize immediately. You can order this input so that later declarations depend on earlier ones (including inputs or captures). If you need to depend on values that will be computed later at runtime, use [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var") at an appropriate point in the circuit execution. - ## Methods + This argument is intended for convenient circuit initialization when you already have a set of created variables. The variables used here will be directly passed to [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var"), which you can use directly if this is the first time you are creating the variable. - ### add\_bits + **Raises** - - Add Bits to the circuit. + * [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the circuit name, if given, is not valid. + * [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if both `inputs` and `captures` are given. - ### add\_calibration + If you have an existing circuit, you can produce a copy of it using [`copy()`](#qiskit.circuit.QuantumCircuit.copy "qiskit.circuit.QuantumCircuit.copy"), including all its instructions. This is useful if you want to keep partial circuits while extending another, or to have a version you can mutate in-place while leaving the prior one intact. - - Register a low-level, custom pulse definition for the given gate. + ### copy + + + Copy the circuit. **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. + **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. - **Raises** + **Returns** - [**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. + a deepcopy of the current circuit, with the specified name + + **Return type** + + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ### add\_capture + Similarly, if you want a circuit that contains all the same data objects (bits, registers, variables, etc) but with none of the instructions, you can use [`copy_empty_like()`](#qiskit.circuit.QuantumCircuit.copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like"). This is quite common when you want to build up a new layer of a circuit to then use apply onto the back with [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose"), or to do a full rewrite of a circuit’s instructions. - - Add a variable to the circuit that it should capture from a scope it will be contained within. + ### copy\_empty\_like - This method requires a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node to enforce that you’ve got a handle to one, because you will need to declare the same variable using the same object into the outer circuit. + + Return a copy of self with the same structure but empty. - This is a low-level method, which is only really useful if you are manually constructing control-flow operations. You typically will not need to call this method, assuming you are using the builder interface for control-flow scopes (`with` context-manager statements for [`if_test()`](#qiskit.circuit.QuantumCircuit.if_test "qiskit.circuit.QuantumCircuit.if_test") and the other scoping constructs). The builder interface will automatically make the inner scopes closures on your behalf by capturing any variables that are used within them. + That structure includes: + + * name, calibrations and other metadata + * global phase + * all the qubits and clbits, including the registers + * the realtime variables defined in the circuit, handled according to the `vars` keyword argument. + + + If the circuit contains any local variable declarations (those added by the `declarations` argument to the circuit constructor, or using [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var")), they may be **uninitialized** in the output circuit. You will need to manually add store instructions for them (see [`Store`](circuit#qiskit.circuit.Store "qiskit.circuit.Store") and [`QuantumCircuit.store()`](#qiskit.circuit.QuantumCircuit.store "qiskit.circuit.QuantumCircuit.store")) to initialize them. + **Parameters** - **var** ([*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")) – the variable to capture from an enclosing scope. + * **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name for the copied circuit. If None, then the name stays the same. - **Raises** + * **vars\_mode** (*Literal\['alike', 'captures', 'drop']*) – - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the variable cannot be created due to shadowing an existing variable. - + The mode to handle realtime variables in. - ### add\_input + **alike** - - Register a variable as an input to the circuit. + The variables in the output circuit will have the same declaration semantics as in the original circuit. For example, `input` variables in the source will be `input` variables in the output circuit. - **Parameters** + **captures** - * **name\_or\_var** – either a string name, or an existing [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node to use as the input variable. - * **type** – if the name is given as a string, then this must be a [`Type`](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type") to use for the variable. If the variable is given as an existing [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var"), then this must not be given, and will instead be read from the object itself. + All variables will be converted to captured variables. This is useful when you are building a new layer for an existing circuit that you will want to [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") onto the base, since [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") can inline captures onto the base circuit (but not other variables). - **Returns** + **drop** - the variable created, or the same variable as was passed in. + The output circuit will have no variables defined. - **Raises** + **Returns** - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the variable cannot be created due to shadowing an existing variable. - + An empty copy of self. - ### add\_register + **Return type** - - Add registers. + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ### add\_uninitialized\_var + In some cases, it is most convenient to generate a list of [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s separately to an entire circuit context, and then to build a circuit from this. The [`from_instructions()`](#qiskit.circuit.QuantumCircuit.from_instructions "qiskit.circuit.QuantumCircuit.from_instructions") constructor will automatically capture all [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit") and [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") instances used in the instructions, and create a new [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") object that has the correct resources and all the instructions. - - Add a variable with no initializer. + ### from\_instructions - In most cases, you should use [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var") to initialize the variable. To use this function, you must already hold a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instance, as the use of the function typically only makes sense in copying contexts. + + Construct a circuit from an iterable of [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s. - - Qiskit makes no assertions about what an uninitialized variable will evaluate to at runtime, and some hardware may reject this as an error. + **Parameters** - You should treat this function with caution, and as a low-level primitive that is useful only in special cases of programmatically rebuilding two like circuits. + * **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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*], Iterable\[*[*Clbit*](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit")*]]]*) – The instructions to add to the circuit. + * **qubits** (*Iterable\[*[*Qubit*](circuit#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*](circuit#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") + + + [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") also still has two constructor methods that are legacy wrappers around the importers in [`qiskit.qasm2`](qasm2#module-qiskit.qasm2 "qiskit.qasm2"). These automatically apply [the legacy compatibility settings](qasm2#qasm2-legacy-compatibility) of [`load()`](qasm2#qiskit.qasm2.load "qiskit.qasm2.load") and [`loads()`](qasm2#qiskit.qasm2.loads "qiskit.qasm2.loads"). + + ### from\_qasm\_file + + + 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 + + + Convert a string containing an OpenQASM 2.0 program to a [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). **Parameters** - **var** ([*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")) – the variable to add. + **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. + + + + ## Data objects on circuits + + + + ### Adding data objects + + | Method | Adds this kind of data | + | --------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | + | [`add_bits()`](#qiskit.circuit.QuantumCircuit.add_bits "qiskit.circuit.QuantumCircuit.add_bits") | [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")s and [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit")s. | + | [`add_register()`](#qiskit.circuit.QuantumCircuit.add_register "qiskit.circuit.QuantumCircuit.add_register") | [`QuantumRegister`](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") and [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister"). | + | [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var") | [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes with local scope and initializers. | + | [`add_input()`](#qiskit.circuit.QuantumCircuit.add_input "qiskit.circuit.QuantumCircuit.add_input") | [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes that are treated as circuit inputs. | + | [`add_capture()`](#qiskit.circuit.QuantumCircuit.add_capture "qiskit.circuit.QuantumCircuit.add_capture") | [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes captured from containing scopes. | + | [`add_uninitialized_var()`](#qiskit.circuit.QuantumCircuit.add_uninitialized_var "qiskit.circuit.QuantumCircuit.add_uninitialized_var") | [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes with local scope and undefined state. | + + Typically you add most of the data objects ([`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit"), [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit"), [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister"), etc) to the circuit as part of using the [`__init__()`](#qiskit.circuit.QuantumCircuit.__init__ "qiskit.circuit.QuantumCircuit.__init__") default constructor, or [`copy_empty_like()`](#qiskit.circuit.QuantumCircuit.copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like"). However, it is also possible to add these afterwards. Typed classical data, such as standalone [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes (see [Real-time classical computation](circuit#circuit-repr-real-time-classical)), can be both constructed and added with separate methods. + + New registerless [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit") and [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") objects are added using [`add_bits()`](#qiskit.circuit.QuantumCircuit.add_bits "qiskit.circuit.QuantumCircuit.add_bits"). These objects must not already be present in the circuit. You can check if a bit exists in the circuit already using [`find_bit()`](#qiskit.circuit.QuantumCircuit.find_bit "qiskit.circuit.QuantumCircuit.find_bit"). + + #### add\_bits + + + Add Bits to the circuit. + + + Registers are added to the circuit with [`add_register()`](#qiskit.circuit.QuantumCircuit.add_register "qiskit.circuit.QuantumCircuit.add_register"). In this method, it is not an error if some of the bits are already present in the circuit. In this case, the register will be an “alias” over the bits. This is not generally well-supported by hardware backends; it is probably best to stay away from relying on it. The registers a given bit is in are part of the return of [`find_bit()`](#qiskit.circuit.QuantumCircuit.find_bit "qiskit.circuit.QuantumCircuit.find_bit"). + + #### add\_register + + + Add registers. - ### add\_var + [Real-time, typed classical data](circuit#circuit-repr-real-time-classical) is represented on the circuit by [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes with a well-defined [`Type`](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type"). It is possible to instantiate these separately to a circuit (see [`Var.new()`](circuit_classical#qiskit.circuit.classical.expr.Var.new "qiskit.circuit.classical.expr.Var.new")), but it is often more convenient to use circuit methods that will automatically manage the types and expression initialization for you. The two most common methods are [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var") (locally scoped variables) and [`add_input()`](#qiskit.circuit.QuantumCircuit.add_input "qiskit.circuit.QuantumCircuit.add_input") (inputs to the circuit). + + #### add\_var - + Add a classical variable with automatic storage and scope to this circuit. The variable is considered to have been “declared” at the beginning of the circuit, but it only becomes initialized at the point of the circuit that you call this method, so it can depend on variables defined before it. @@ -412,7 +547,7 @@ python_api_name: qiskit.circuit.QuantumCircuit * **initial** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – - the value to initialize this variable with. If the first argument was given as a string name, the type of the resulting variable is inferred from the initial expression; to control this more manually, either use `Var.new()` to manually construct a new variable with the desired type, or use [`expr.cast()`](circuit_classical#qiskit.circuit.classical.expr.cast "qiskit.circuit.classical.expr.cast") to cast the initializer to the desired type. + the value to initialize this variable with. If the first argument was given as a string name, the type of the resulting variable is inferred from the initial expression; to control this more manually, either use [`Var.new()`](circuit_classical#qiskit.circuit.classical.expr.Var.new "qiskit.circuit.classical.expr.Var.new") to manually construct a new variable with the desired type, or use [`expr.cast()`](circuit_classical#qiskit.circuit.classical.expr.cast "qiskit.circuit.classical.expr.cast") to cast the initializer to the desired type. This must be either a [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") node, or a value that can be lifted to one using `expr.lift`. @@ -469,38 +604,159 @@ python_api_name: qiskit.circuit.QuantumCircuit ``` - ### append + #### add\_input - - Append one or more instructions to the end of the circuit, modifying the circuit in place. + + Register a variable as an input to the circuit. - 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`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") specifiers (such as integer indices) will be resolved into the relevant instances. + **Parameters** - 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. + * **name\_or\_var** – either a string name, or an existing [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node to use as the input variable. + * **type** – if the name is given as a string, then this must be a [`Type`](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type") to use for the variable. If the variable is given as an existing [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var"), then this must not be given, and will instead be read from the object itself. + + **Returns** + + the variable created, or the same variable as was passed in. + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the variable cannot be created due to shadowing an existing variable. + + + In addition, there are two lower-level methods that can be useful for programmatic generation of circuits. When working interactively, you will most likely not need these; most uses of [`add_uninitialized_var()`](#qiskit.circuit.QuantumCircuit.add_uninitialized_var "qiskit.circuit.QuantumCircuit.add_uninitialized_var") are part of [`copy_empty_like()`](#qiskit.circuit.QuantumCircuit.copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like"), and most uses of [`add_capture()`](#qiskit.circuit.QuantumCircuit.add_capture "qiskit.circuit.QuantumCircuit.add_capture") would be better off using [the control-flow builder interface](#circuit-control-flow-methods). + + #### add\_uninitialized\_var + + + Add a variable with no initializer. + + In most cases, you should use [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var") to initialize the variable. To use this function, you must already hold a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instance, as the use of the function typically only makes sense in copying contexts. + + + Qiskit makes no assertions about what an uninitialized variable will evaluate to at runtime, and some hardware may reject this as an error. + + You should treat this function with caution, and as a low-level primitive that is useful only in special cases of programmatically rebuilding two like circuits. + **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`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")s to attach instruction to. - * **cargs** (*Sequence\[ClbitSpecifier] | None*) – specifiers of the [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit")s to attach instruction to. - * **copy** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if `True` (the default), then the incoming `instruction` is copied before adding it to the circuit if it contains symbolic parameters, so it can be safely mutated without affecting other circuits the same instruction might be in. If you are sure this instruction will not be in other circuits, you can set this `False` for a small speedup. + **var** ([*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")) – the variable to add. + + + #### add\_capture + + + Add a variable to the circuit that it should capture from a scope it will be contained within. + + This method requires a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node to enforce that you’ve got a handle to one, because you will need to declare the same variable using the same object into the outer circuit. + + This is a low-level method, which is only really useful if you are manually constructing control-flow operations. You typically will not need to call this method, assuming you are using the builder interface for control-flow scopes (`with` context-manager statements for [`if_test()`](#qiskit.circuit.QuantumCircuit.if_test "qiskit.circuit.QuantumCircuit.if_test") and the other scoping constructs). The builder interface will automatically make the inner scopes closures on your behalf by capturing any variables that are used within them. + + **Parameters** + + **var** ([*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")) – the variable to capture from an enclosing scope. + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the variable cannot be created due to shadowing an existing variable. + + + ### Working with bits and registers + + A [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") instance is, on its own, just a unique handle for circuits to use in their own contexts. If you have got a [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") instance and a cirucit, just can find the contexts that the bit exists in using [`find_bit()`](#qiskit.circuit.QuantumCircuit.find_bit "qiskit.circuit.QuantumCircuit.find_bit"), such as its integer index in the circuit and any registers it is contained in. + + #### find\_bit + + + Find locations in the circuit which can be used to reference a given [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit"). + + In particular, this function can find the integer index of a qubit, which corresponds to its hardware index for a transpiled circuit. + + + The circuit index of a [`AncillaQubit`](circuit#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"). + + + **Parameters** + + **bit** ([*Bit*](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit")) – The bit to locate. **Returns** - a handle to the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s that were actually added to the circuit. + 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`](circuit#qiskit.circuit.Register "qiskit.circuit.Register") in the circuit which contains the [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") (and the index in the [`Register`](circuit#qiskit.circuit.Register "qiskit.circuit.Register") at which it can be found). **Return type** - [qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + namedtuple([int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"), List\[Tuple([Register](circuit#qiskit.circuit.Register "qiskit.circuit.Register"), [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"))]) **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") . + * [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the supplied [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") was of an unknown type. + * [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the supplied [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") could not be found on the circuit. + + **Examples** + + Loop through a circuit, getting the qubit and clbit indices of each operation: + + ```python + from qiskit.circuit import QuantumCircuit, Qubit + + qc = QuantumCircuit(3, 3) + qc.h(0) + qc.cx(0, 1) + qc.cx(1, 2) + qc.measure([0, 1, 2], [0, 1, 2]) + + # The `.qubits` and `.clbits` fields are not integers. + assert isinstance(qc.data[0].qubits[0], Qubit) + # ... but we can use `find_bit` to retrieve them. + assert qc.find_bit(qc.data[0].qubits[0]).index == 0 + + simple = [ + ( + instruction.operation.name, + [qc.find_bit(bit).index for bit in instruction.qubits], + [qc.find_bit(bit).index for bit in instruction.clbits], + ) + for instruction in qc.data + ] + ``` + + + Similarly, you can query a circuit to see if a register has already been added to it by using [`has_register()`](#qiskit.circuit.QuantumCircuit.has_register "qiskit.circuit.QuantumCircuit.has_register"). + + #### has\_register + + + Test if this circuit has the register r. + + **Parameters** + + **register** ([*Register*](circuit#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)") - ### assign\_parameters + ### Working with compile-time parameters + + + **[Compile-time parametrization](circuit#circuit-compile-time-parameters)** + + A more complete discussion of what compile-time parametrization is, and how it fits into Qiskit’s data model. + + + Unlike bits, registers, and real-time typed classical data, compile-time symbolic parameters are not manually added to a circuit. Their presence is inferred by being contained in operations added to circuits and the global phase. An ordered list of all parameters currently in a circuit is at [`QuantumCircuit.parameters`](#qiskit.circuit.QuantumCircuit.parameters "qiskit.circuit.QuantumCircuit.parameters"). + + The most common operation on [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances is to replace them in symbolic operations with some numeric value, or another symbolic expression. This is done with [`assign_parameters()`](#qiskit.circuit.QuantumCircuit.assign_parameters "qiskit.circuit.QuantumCircuit.assign_parameters"). + + #### assign\_parameters - + Assign parameters to new parameters or values. If `parameters` is passed as a dictionary, the keys should 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. @@ -547,9 +803,9 @@ python_api_name: qiskit.circuit.QuantumCircuit circuit.draw('mpl') ``` - ![../\_images/qiskit-circuit-QuantumCircuit-3\_00.png](/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-3_00.png) + ![../\_images/qiskit-circuit-QuantumCircuit-1\_00.png](/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-1_00.png) - ![../\_images/qiskit-circuit-QuantumCircuit-3\_01.png](/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-3_01.png) + ![../\_images/qiskit-circuit-QuantumCircuit-1\_01.png](/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-1_01.png) Bind the values out-of-place by list and get a copy of the original circuit. @@ -567,184 +823,349 @@ python_api_name: qiskit.circuit.QuantumCircuit circuit.draw('mpl') ``` - ![../\_images/qiskit-circuit-QuantumCircuit-4\_00.png](/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-4_00.png) + ![../\_images/qiskit-circuit-QuantumCircuit-2\_00.png](/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-2_00.png) - ![../\_images/qiskit-circuit-QuantumCircuit-4\_01.png](/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-4_01.png) + ![../\_images/qiskit-circuit-QuantumCircuit-2\_01.png](/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-2_01.png) - ### barrier + The circuit tracks parameters by [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances themselves, and forbids having multiple parameters of the same name to avoid some problems when interoperating with OpenQASM or other external formats. You can use [`has_parameter()`](#qiskit.circuit.QuantumCircuit.has_parameter "qiskit.circuit.QuantumCircuit.has_parameter") and [`get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter") to query the circuit for a parameter with the given string name. - - Apply `Barrier`. If `qargs` is empty, applies to all qubits in the circuit. + #### has\_parameter + + + Check whether a parameter object exists in this 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. + **name\_or\_param** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")) – the parameter, or name of a parameter to check. If this is a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") node, the parameter must be exactly the given one for this function to return `True`. **Returns** - handle to the added instructions. + whether a matching parameter is assignable in this circuit. **Return type** - [qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") - ### break\_loop + + **[`QuantumCircuit.get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter")** - - Apply [`BreakLoopOp`](qiskit.circuit.BreakLoopOp "qiskit.circuit.BreakLoopOp"). + Retrieve the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instance from this circuit by name. - - 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. + **[`QuantumCircuit.has_var()`](#qiskit.circuit.QuantumCircuit.has_var "qiskit.circuit.QuantumCircuit.has_var")** + + A similar method to this, but for run-time [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") variables instead of compile-time [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")s. + + + #### get\_parameter + + + Retrieve a compile-time parameter that is accessible in this circuit scope by name. + + **Parameters** + + * **name** – the name of the parameter to retrieve. + * **default** – if given, this value will be returned if the parameter is not present. If it is not given, a [`KeyError`](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") is raised instead. **Returns** - A handle to the instruction created. + The corresponding parameter. **Raises** - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if this method was called within a builder context, but not contained within a loop. + [**KeyError**](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") – if no default is given, but the parameter does not exist in the circuit. - **Return type** + **Examples** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - + Retrieve a parameter by name from a circuit: - ### cast + ```python + from qiskit.circuit import QuantumCircuit, Parameter - - Best effort to cast value to type. Otherwise, returns the value. + my_param = Parameter("my_param") - **Return type** + # Create a parametrised circuit. + qc = QuantumCircuit(1) + qc.rx(my_param, 0) - *S* | *T* + # We can use 'my_param' as a parameter, but let's say we've lost the Python object + # and need to retrieve it. + my_param_again = qc.get_parameter("my_param") + + assert my_param is my_param_again + ``` + + Get a variable from a circuit by name, returning some default if it is not present: + + ```python + assert qc.get_parameter("my_param", None) is my_param + assert qc.get_parameter("unknown_param", None) is None + ``` + + + **[`get_var()`](#qiskit.circuit.QuantumCircuit.get_var "qiskit.circuit.QuantumCircuit.get_var")** + + A similar method, but for [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") run-time variables instead of [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") compile-time parameters. + - ### cbit\_argument\_conversion + - - Converts several classical bit representations (such as indexes, range, etc.) into a list of classical bits. + ### Working with real-time typed classical data - **Parameters** + + **[`qiskit.circuit.classical`](circuit_classical#module-qiskit.circuit.classical "qiskit.circuit.classical")** - **clbit\_representation** (*Object*) – representation to expand + Module-level documentation for how the variable-, expression- and type-systems work, the objects used to represent them, and the classical operations available. - **Returns** + **[Real-time classical computation](circuit#circuit-repr-real-time-classical)** - Where each tuple is a classical bit. + A discussion of how real-time data fits into the entire [`qiskit.circuit`](circuit#module-qiskit.circuit "qiskit.circuit") data model as a whole. - **Return type** + **[Adding data objects](#circuit-adding-data-objects)** - List([tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) - + The methods for adding new [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") variables to a circuit after initialization. + - ### ccx + You can retrive a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instance attached to a circuit by using its variable name using [`get_var()`](#qiskit.circuit.QuantumCircuit.get_var "qiskit.circuit.QuantumCircuit.get_var"), or check if a circuit contains a given variable with [`has_var()`](#qiskit.circuit.QuantumCircuit.has_var "qiskit.circuit.QuantumCircuit.has_var"). - - Apply [`CCXGate`](qiskit.circuit.library.CCXGate "qiskit.circuit.library.CCXGate"). + #### get\_var - For the full matrix form of this gate, see the underlying gate documentation. + + Retrieve a variable that is accessible in this circuit scope by name. **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. + * **name** – the name of the variable to retrieve. + * **default** – if given, this value will be returned if the variable is not present. If it is not given, a [`KeyError`](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") is raised instead. **Returns** - A handle to the instructions created. + The corresponding variable. - **Return type** + **Raises** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - + [**KeyError**](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") – if no default is given, but the variable does not exist. - ### ccz + **Examples** - - Apply [`CCZGate`](qiskit.circuit.library.CCZGate "qiskit.circuit.library.CCZGate"). + Retrieve a variable by name from a circuit: - For the full matrix form of this gate, see the underlying gate documentation. + ```python + from qiskit.circuit import QuantumCircuit + + # Create a circuit and create a variable in it. + qc = QuantumCircuit() + my_var = qc.add_var("my_var", False) + + # We can use 'my_var' as a variable, but let's say we've lost the Python object and + # need to retrieve it. + my_var_again = qc.get_var("my_var") + + assert my_var is my_var_again + ``` + + Get a variable from a circuit by name, returning some default if it is not present: + + ```python + assert qc.get_var("my_var", None) is my_var + assert qc.get_var("unknown_variable", None) is None + ``` + + + **[`get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter")** + + A similar method, but for [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") compile-time parameters instead of [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") run-time variables. + + + + #### has\_var + + + Check whether a variable is accessible in this scope. **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. + **name\_or\_var** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")) – the variable, or name of a variable to check. If this is a [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node, the variable must be exactly the given one for this function to return `True`. **Returns** - A handle to the instructions created. + whether a matching variable is accessible. **Return type** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + **[`QuantumCircuit.get_var()`](#qiskit.circuit.QuantumCircuit.get_var "qiskit.circuit.QuantumCircuit.get_var")** + + Retrieve the [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instance from this circuit by name. + + **[`QuantumCircuit.has_parameter()`](#qiskit.circuit.QuantumCircuit.has_parameter "qiskit.circuit.QuantumCircuit.has_parameter")** + + A similar method to this, but for compile-time [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")s instead of run-time [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") variables. + - ### ch + There are also several iterator methods that you can use to get the full set of variables tracked by a circuit. At least one of [`iter_input_vars()`](#qiskit.circuit.QuantumCircuit.iter_input_vars "qiskit.circuit.QuantumCircuit.iter_input_vars") and [`iter_captured_vars()`](#qiskit.circuit.QuantumCircuit.iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars") will be empty, as inputs and captures are mutually exclusive. All of the iterators have corresponding dynamic properties on [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") that contain their length: [`num_vars`](#qiskit.circuit.QuantumCircuit.num_vars "qiskit.circuit.QuantumCircuit.num_vars"), [`num_input_vars`](#qiskit.circuit.QuantumCircuit.num_input_vars "qiskit.circuit.QuantumCircuit.num_input_vars"), [`num_captured_vars`](#qiskit.circuit.QuantumCircuit.num_captured_vars "qiskit.circuit.QuantumCircuit.num_captured_vars") and [`num_declared_vars`](#qiskit.circuit.QuantumCircuit.num_declared_vars "qiskit.circuit.QuantumCircuit.num_declared_vars"). - - Apply [`CHGate`](qiskit.circuit.library.CHGate "qiskit.circuit.library.CHGate"). + #### iter\_vars - For the full matrix form of this gate, see the underlying gate documentation. + + Get an iterable over all real-time classical variables in scope within this circuit. - **Parameters** + This method will iterate over all variables in scope. For more fine-grained iterators, see [`iter_declared_vars()`](#qiskit.circuit.QuantumCircuit.iter_declared_vars "qiskit.circuit.QuantumCircuit.iter_declared_vars"), [`iter_input_vars()`](#qiskit.circuit.QuantumCircuit.iter_input_vars "qiskit.circuit.QuantumCircuit.iter_input_vars") and [`iter_captured_vars()`](#qiskit.circuit.QuantumCircuit.iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars"). - * **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. + **Return type** - **Returns** + [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")] + - A handle to the instructions created. + #### iter\_input\_vars + + + Get an iterable over all real-time classical variables that are declared as inputs to this circuit scope. This excludes locally declared variables (see [`iter_declared_vars()`](#qiskit.circuit.QuantumCircuit.iter_declared_vars "qiskit.circuit.QuantumCircuit.iter_declared_vars")) and captured variables (see [`iter_captured_vars()`](#qiskit.circuit.QuantumCircuit.iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars")). **Return type** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")] - ### clear + #### iter\_captured\_vars - - Clear all instructions in self. + + Get an iterable over all real-time classical variables that are captured by this circuit scope from a containing scope. This excludes input variables (see [`iter_input_vars()`](#qiskit.circuit.QuantumCircuit.iter_input_vars "qiskit.circuit.QuantumCircuit.iter_input_vars")) and locally declared variables (see [`iter_declared_vars()`](#qiskit.circuit.QuantumCircuit.iter_declared_vars "qiskit.circuit.QuantumCircuit.iter_declared_vars")). - Clearing the circuits will keep the metadata and calibrations. + **Return type** + + [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")] - ### cls\_instances + #### iter\_declared\_vars - - Return the current number of instances of this class, useful for auto naming. + + Get an iterable over all real-time classical variables that are declared with automatic storage duration in this scope. This excludes input variables (see [`iter_input_vars()`](#qiskit.circuit.QuantumCircuit.iter_input_vars "qiskit.circuit.QuantumCircuit.iter_input_vars")) and captured variables (see [`iter_captured_vars()`](#qiskit.circuit.QuantumCircuit.iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars")). **Return type** - [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)")\[[*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")] - ### cls\_prefix + - - Return the prefix to use for auto naming. + ## Adding operations to circuits + + You can add anything that implements the [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") interface to a circuit as a single instruction, though most things you will want to add will be [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") or [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") instances. + + + **[Operations, instructions and gates](circuit#circuit-operations-instructions)** + + The [`qiskit.circuit`](circuit#module-qiskit.circuit "qiskit.circuit")-level documentation on the different interfaces that Qiskit uses to define circuit-level instructions. + + + + + ### Methods to add general operations + + These are the base methods that handle adding any object, including user-defined ones, onto circuits. + + | Method | When to use it | + | --------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------- | + | [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") | Add an instruction as a single object onto a circuit. | + | [`_append()`](#qiskit.circuit.QuantumCircuit._append "qiskit.circuit.QuantumCircuit._append") | Same as [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append"), but a low-level interface that elides almost all error checking. | + | [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") | Inline the instructions from one circuit onto another. | + | [`tensor()`](#qiskit.circuit.QuantumCircuit.tensor "qiskit.circuit.QuantumCircuit.tensor") | Like [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose"), but strictly for joining circuits that act on disjoint qubits. | + + [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") has two main ways that you will add more operations onto a circuit. Which to use depends on whether you want to add your object as a single “instruction” ([`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append")), or whether you want to join the instructions from two circuits together ([`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose")). + + A single instruction or operation appears as a single entry in the [`data`](#qiskit.circuit.QuantumCircuit.data "qiskit.circuit.QuantumCircuit.data") of the circuit, and as a single box when drawn in the circuit visualizers (see [`draw()`](#qiskit.circuit.QuantumCircuit.draw "qiskit.circuit.QuantumCircuit.draw")). A single instruction is the “unit” that a hardware backend might be defined in terms of (see [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target")). An [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") can come with a [`definition`](qiskit.circuit.Instruction#definition "qiskit.circuit.Instruction.definition"), which is one rule the transpiler (see [`qiskit.transpiler`](transpiler#module-qiskit.transpiler "qiskit.transpiler")) will be able to fall back on to decompose it for hardware, if needed. An [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") that is not also an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") can only be decomposed if it has some associated high-level synthesis method registered for it (see [`qiskit.transpiler.passes.synthesis.plugin`](transpiler_synthesis_plugins#module-qiskit.transpiler.passes.synthesis.plugin "qiskit.transpiler.passes.synthesis.plugin")). + + A [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") alone is not a single [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"); it is rather more complicated, since it can, in general, represent a complete program with typed classical memory inputs and outputs, and control flow. Qiskit’s (and most hardware’s) data model does not yet have the concept of re-usable callable subroutines with virtual quantum operands. You can convert simple circuits that act only on qubits with unitary operations into a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") using [`to_gate()`](#qiskit.circuit.QuantumCircuit.to_gate "qiskit.circuit.QuantumCircuit.to_gate"), and simple circuits acting only on qubits and clbits into a [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") with [`to_instruction()`](#qiskit.circuit.QuantumCircuit.to_instruction "qiskit.circuit.QuantumCircuit.to_instruction"). + + When you have an [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation"), [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"), or [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"), add it to the circuit, specifying the qubit and clbit arguments with [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append"). + + #### append + + + 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`](circuit#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`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")s to attach instruction to. + * **cargs** (*Sequence\[ClbitSpecifier] | None*) – specifiers of the [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit")s to attach instruction to. + * **copy** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if `True` (the default), then the incoming `instruction` is copied before adding it to the circuit if it contains symbolic parameters, so it can be safely mutated without affecting other circuits the same instruction might be in. If you are sure this instruction will not be in other circuits, you can set this `False` for a small speedup. + + **Returns** + + a handle to the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s that were actually added to the circuit. **Return type** - [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + [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") . + + + [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") does quite substantial error checking to ensure that you cannot accidentally break the data model of [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). If you are programmatically generating a circuit from known-good data, you can elide much of this error checking by using the fast-path appender [`_append()`](#qiskit.circuit.QuantumCircuit._append "qiskit.circuit.QuantumCircuit._append"), but at the risk that the caller is responsible for ensuring they are passing only valid data. + + #### \_append + + + Append an instruction to the end of the circuit, modifying the circuit in place. + + + This is an internal fast-path function, and it is the responsibility of the caller to ensure that all the arguments are valid; there is no error checking here. In particular: + + * all the qubits and clbits must already exist in the circuit and there can be no duplicates in the list. + * any control-flow operations or classically conditioned instructions must act only on variables present in the circuit. + * the circuit must not be within a control-flow builder context. + + + + This function may be used by callers other than [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") when the caller is sure that all error-checking, broadcasting and scoping has already been performed, and the only reference to the circuit the instructions are being appended to is within that same function. In particular, it is not safe to call [`QuantumCircuit._append()`](#qiskit.circuit.QuantumCircuit._append "qiskit.circuit.QuantumCircuit._append") on a circuit that is received by a function argument. This is because [`QuantumCircuit._append()`](#qiskit.circuit.QuantumCircuit._append "qiskit.circuit.QuantumCircuit._append") will not recognise the scoping constructs of the control-flow builder interface. + + + **Parameters** + + * **instruction** – + + A complete well-formed [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") of the operation and its context to be added. + + In the legacy compatibility form, this can be a bare [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation"), in which case `qargs` and `cargs` must be explicitly given. + + * **qargs** – Legacy argument for qubits to attach the bare [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") to. Ignored if the first argument is in the preferential [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") form. + + * **cargs** – Legacy argument for clbits to attach the bare [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") to. Ignored if the first argument is in the preferential [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") form. + + **Returns** + + a handle to the instruction that was just added. + + **Return type** + + [CircuitInstruction](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") - ### compose + In other cases, you may want to join two circuits together, applying the instructions from one circuit onto specified qubits and clbits on another circuit. This “inlining” operation is called [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") in Qiskit. [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") is, in general, more powerful than a [`to_instruction()`](#qiskit.circuit.QuantumCircuit.to_instruction "qiskit.circuit.QuantumCircuit.to_instruction")-plus-[`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") combination for joining two circuits, because it can also link typed classical data together, and allows for circuit control-flow operations to be joined onto another circuit. - - Compose circuit with `other` circuit or instruction, optionally permuting wires. + The downsides to [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") are that it is a more complex operation that can involve more rewriting of the operand, and that it necessarily must move data from one circuit object to another. If you are building up a circuit for yourself and raw performance is a core goal, consider passing around your base circuit and having different parts of your algorithm write directly to the base circuit, rather than building a temporary layer circuit. - `other` can be narrower or of equal width to `self`. + #### compose + + + Apply the instructions from one circuit onto specified qubits and/or clbits on another. + + + By default, this creates a new circuit object, leaving `self` untouched. For most uses of this function, it is far more efficient to set `inplace=True` and modify the base circuit in-place. + When dealing with realtime variables ([`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instances), there are two principal strategies for using [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose"): @@ -763,8 +1184,6 @@ python_api_name: qiskit.circuit.QuantumCircuit * **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. - * **copy** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True` (the default), then the input is treated as shared, and any contained instructions will be copied, if they might need to be mutated in the future. You can set this to `False` if the input should be considered owned by the base circuit, in order to avoid unnecessary copies; in this case, it is not valid to use `other` afterwards, and some instructions may have been mutated in place. * **var\_remap** (*Mapping*) – @@ -779,6 +1198,8 @@ python_api_name: qiskit.circuit.QuantumCircuit If this is `False` (the default), then all variables in `other` will be required to be distinct from those in `self`, and new declarations will be made for them. + * **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. Rather than using this option, it is almost always better to manually control this yourself by using [`to_instruction()`](#qiskit.circuit.QuantumCircuit.to_instruction "qiskit.circuit.QuantumCircuit.to_instruction") or [`to_gate()`](#qiskit.circuit.QuantumCircuit.to_gate "qiskit.circuit.QuantumCircuit.to_gate"), and then call [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append"). + **Returns** the composed circuit (returns None if inplace==True). @@ -817,133 +1238,244 @@ python_api_name: qiskit.circuit.QuantumCircuit ``` - ### continue\_loop + If you are trying to join two circuits that will apply to completely disjoint qubits and clbits, [`tensor()`](#qiskit.circuit.QuantumCircuit.tensor "qiskit.circuit.QuantumCircuit.tensor") is a convenient wrapper around manually adding bit objects and calling [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose"). - - Apply [`ContinueLoopOp`](qiskit.circuit.ContinueLoopOp "qiskit.circuit.ContinueLoopOp"). + #### tensor - - 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. - + + Tensor `self` with `other`. - **Returns** + Remember that in the little-endian convention the leftmost operation will be at the bottom of the circuit. See also [the docs](/build/circuit-construction) for more information. - A handle to the instruction created. + ```python + ┌────────┐ ┌─────┐ ┌─────┐ + q_0: ┤ bottom ├ ⊗ q_0: ┤ top ├ = q_0: ─┤ top ├── + └────────┘ └─────┘ ┌┴─────┴─┐ + q_1: ┤ bottom ├ + └────────┘ + ``` - **Raises** + **Parameters** - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if this method was called within a builder context, but not contained within a loop. + * **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** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - - - ### control + [*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") | None - - Control this circuit on `num_ctrl_qubits` qubits. + **Examples** - **Parameters** + ```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') + ``` - * **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`. - * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + ![../\_images/qiskit-circuit-QuantumCircuit-3.png](/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-3.png) **Returns** - The controlled version of this circuit. + The tensored 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 the circuit contains a non-unitary operation and cannot be controlled. - ### copy - - - Copy the circuit. + As some rules of thumb: + + * If you have a single [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation"), [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") or [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"), you should definitely use [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") or [`_append()`](#qiskit.circuit.QuantumCircuit._append "qiskit.circuit.QuantumCircuit._append"). + * If you have a [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") that represents a single atomic instruction for a larger circuit that you want to re-use, you probably want to call [`to_instruction()`](#qiskit.circuit.QuantumCircuit.to_instruction "qiskit.circuit.QuantumCircuit.to_instruction") or [`to_gate()`](#qiskit.circuit.QuantumCircuit.to_gate "qiskit.circuit.QuantumCircuit.to_gate"), and then apply the result of that to the circuit using [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append"). + * If you have a [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") that represents a larger “layer” of another circuit, or contains typed classical variables or control flow, you should use [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") to merge it onto another circuit. + * [`tensor()`](#qiskit.circuit.QuantumCircuit.tensor "qiskit.circuit.QuantumCircuit.tensor") is wanted far more rarely than either [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") or [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose"). Internally, it is mostly a wrapper around [`add_bits()`](#qiskit.circuit.QuantumCircuit.add_bits "qiskit.circuit.QuantumCircuit.add_bits") and [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose"). + + Some potential pitfalls to beware of: + + * Even if you re-use a custom [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") during circuit construction, the transpiler will generally have to “unroll” each invocation of it to its inner decomposition before beginning work on it. This should not prevent you from using the [`to_instruction()`](#qiskit.circuit.QuantumCircuit.to_instruction "qiskit.circuit.QuantumCircuit.to_instruction")-plus-[`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") pattern, as the transpiler will improve in this regard over time. + * [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") will, by default, produce a new circuit for backwards compatibility. This is more expensive, and not usually what you want, so you should set `inplace=True`. + * Both [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") and [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") (but not [`_append()`](#qiskit.circuit.QuantumCircuit._append "qiskit.circuit.QuantumCircuit._append")) have a `copy` keyword argument that defaults to `True`. In these cases, the incoming [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") instances will be copied if Qiskit detects that the objects have mutability about them (such as taking gate parameters). If you are sure that you will not re-use the objects again in other places, you should set `copy=False` to prevent this copying, which can be a substantial speed-up for large objects. + + ### Methods to add standard instructions + + The [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") class has helper methods to add many of the Qiskit standard-library instructions and gates onto a circuit. These are generally equivalent to manually constructing an instance of the relevent [`qiskit.circuit.library`](circuit_library#module-qiskit.circuit.library "qiskit.circuit.library") object, then passing that to [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") with the remaining arguments placed into the `qargs` and `cargs` fields as appropriate. + + The following methods apply special non-unitary [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") operations to the circuit: + + | [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") method | [`qiskit.circuit`](circuit#module-qiskit.circuit "qiskit.circuit") [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") | + | ------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------- | + | [`barrier()`](#qiskit.circuit.QuantumCircuit.barrier "qiskit.circuit.QuantumCircuit.barrier") | [`Barrier`](circuit#qiskit.circuit.Barrier "qiskit.circuit.Barrier") | + | [`delay()`](#qiskit.circuit.QuantumCircuit.delay "qiskit.circuit.QuantumCircuit.delay") | [`Delay`](circuit#qiskit.circuit.Delay "qiskit.circuit.Delay") | + | [`initialize()`](#qiskit.circuit.QuantumCircuit.initialize "qiskit.circuit.QuantumCircuit.initialize") | [`Initialize`](qiskit.circuit.library.Initialize "qiskit.circuit.library.Initialize") | + | [`measure()`](#qiskit.circuit.QuantumCircuit.measure "qiskit.circuit.QuantumCircuit.measure") | [`Measure`](circuit#qiskit.circuit.Measure "qiskit.circuit.Measure") | + | [`reset()`](#qiskit.circuit.QuantumCircuit.reset "qiskit.circuit.QuantumCircuit.reset") | [`Reset`](circuit#qiskit.circuit.Reset "qiskit.circuit.Reset") | + | [`store()`](#qiskit.circuit.QuantumCircuit.store "qiskit.circuit.QuantumCircuit.store") | [`Store`](circuit#qiskit.circuit.Store "qiskit.circuit.Store") | + + These methods apply uncontrolled unitary [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") instances to the circuit: + + | [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") method | [`qiskit.circuit.library`](circuit_library#module-qiskit.circuit.library "qiskit.circuit.library") [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") | + | --------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------ | + | [`dcx()`](#qiskit.circuit.QuantumCircuit.dcx "qiskit.circuit.QuantumCircuit.dcx") | [`DCXGate`](qiskit.circuit.library.DCXGate "qiskit.circuit.library.DCXGate") | + | [`ecr()`](#qiskit.circuit.QuantumCircuit.ecr "qiskit.circuit.QuantumCircuit.ecr") | [`ECRGate`](qiskit.circuit.library.ECRGate "qiskit.circuit.library.ECRGate") | + | [`h()`](#qiskit.circuit.QuantumCircuit.h "qiskit.circuit.QuantumCircuit.h") | [`HGate`](qiskit.circuit.library.HGate "qiskit.circuit.library.HGate") | + | [`id()`](#qiskit.circuit.QuantumCircuit.id "qiskit.circuit.QuantumCircuit.id") | [`IGate`](qiskit.circuit.library.IGate "qiskit.circuit.library.IGate") | + | [`iswap()`](#qiskit.circuit.QuantumCircuit.iswap "qiskit.circuit.QuantumCircuit.iswap") | [`iSwapGate`](qiskit.circuit.library.iSwapGate "qiskit.circuit.library.iSwapGate") | + | [`ms()`](#qiskit.circuit.QuantumCircuit.ms "qiskit.circuit.QuantumCircuit.ms") | [`MSGate`](qiskit.circuit.library.MSGate "qiskit.circuit.library.MSGate") | + | [`p()`](#qiskit.circuit.QuantumCircuit.p "qiskit.circuit.QuantumCircuit.p") | [`PhaseGate`](qiskit.circuit.library.PhaseGate "qiskit.circuit.library.PhaseGate") | + | [`pauli()`](#qiskit.circuit.QuantumCircuit.pauli "qiskit.circuit.QuantumCircuit.pauli") | [`PauliGate`](qiskit.circuit.library.PauliGate "qiskit.circuit.library.PauliGate") | + | [`prepare_state()`](#qiskit.circuit.QuantumCircuit.prepare_state "qiskit.circuit.QuantumCircuit.prepare_state") | [`StatePreparation`](qiskit.circuit.library.StatePreparation "qiskit.circuit.library.StatePreparation") | + | [`r()`](#qiskit.circuit.QuantumCircuit.r "qiskit.circuit.QuantumCircuit.r") | [`RGate`](qiskit.circuit.library.RGate "qiskit.circuit.library.RGate") | + | [`rcccx()`](#qiskit.circuit.QuantumCircuit.rcccx "qiskit.circuit.QuantumCircuit.rcccx") | [`RC3XGate`](qiskit.circuit.library.RC3XGate "qiskit.circuit.library.RC3XGate") | + | [`rccx()`](#qiskit.circuit.QuantumCircuit.rccx "qiskit.circuit.QuantumCircuit.rccx") | [`RCCXGate`](qiskit.circuit.library.RCCXGate "qiskit.circuit.library.RCCXGate") | + | [`rv()`](#qiskit.circuit.QuantumCircuit.rv "qiskit.circuit.QuantumCircuit.rv") | [`RVGate`](qiskit.circuit.library.RVGate "qiskit.circuit.library.RVGate") | + | [`rx()`](#qiskit.circuit.QuantumCircuit.rx "qiskit.circuit.QuantumCircuit.rx") | [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate") | + | [`rxx()`](#qiskit.circuit.QuantumCircuit.rxx "qiskit.circuit.QuantumCircuit.rxx") | [`RXXGate`](qiskit.circuit.library.RXXGate "qiskit.circuit.library.RXXGate") | + | [`ry()`](#qiskit.circuit.QuantumCircuit.ry "qiskit.circuit.QuantumCircuit.ry") | [`RYGate`](qiskit.circuit.library.RYGate "qiskit.circuit.library.RYGate") | + | [`ryy()`](#qiskit.circuit.QuantumCircuit.ryy "qiskit.circuit.QuantumCircuit.ryy") | [`RYYGate`](qiskit.circuit.library.RYYGate "qiskit.circuit.library.RYYGate") | + | [`rz()`](#qiskit.circuit.QuantumCircuit.rz "qiskit.circuit.QuantumCircuit.rz") | [`RZGate`](qiskit.circuit.library.RZGate "qiskit.circuit.library.RZGate") | + | [`rzx()`](#qiskit.circuit.QuantumCircuit.rzx "qiskit.circuit.QuantumCircuit.rzx") | [`RZXGate`](qiskit.circuit.library.RZXGate "qiskit.circuit.library.RZXGate") | + | [`rzz()`](#qiskit.circuit.QuantumCircuit.rzz "qiskit.circuit.QuantumCircuit.rzz") | [`RZZGate`](qiskit.circuit.library.RZZGate "qiskit.circuit.library.RZZGate") | + | [`s()`](#qiskit.circuit.QuantumCircuit.s "qiskit.circuit.QuantumCircuit.s") | [`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate") | + | [`sdg()`](#qiskit.circuit.QuantumCircuit.sdg "qiskit.circuit.QuantumCircuit.sdg") | [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate") | + | [`swap()`](#qiskit.circuit.QuantumCircuit.swap "qiskit.circuit.QuantumCircuit.swap") | [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate") | + | [`sx()`](#qiskit.circuit.QuantumCircuit.sx "qiskit.circuit.QuantumCircuit.sx") | [`SXGate`](qiskit.circuit.library.SXGate "qiskit.circuit.library.SXGate") | + | [`sxdg()`](#qiskit.circuit.QuantumCircuit.sxdg "qiskit.circuit.QuantumCircuit.sxdg") | [`SXdgGate`](qiskit.circuit.library.SXdgGate "qiskit.circuit.library.SXdgGate") | + | [`t()`](#qiskit.circuit.QuantumCircuit.t "qiskit.circuit.QuantumCircuit.t") | [`TGate`](qiskit.circuit.library.TGate "qiskit.circuit.library.TGate") | + | [`tdg()`](#qiskit.circuit.QuantumCircuit.tdg "qiskit.circuit.QuantumCircuit.tdg") | [`TdgGate`](qiskit.circuit.library.TdgGate "qiskit.circuit.library.TdgGate") | + | [`u()`](#qiskit.circuit.QuantumCircuit.u "qiskit.circuit.QuantumCircuit.u") | [`UGate`](qiskit.circuit.library.UGate "qiskit.circuit.library.UGate") | + | [`unitary()`](#qiskit.circuit.QuantumCircuit.unitary "qiskit.circuit.QuantumCircuit.unitary") | [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate") | + | [`x()`](#qiskit.circuit.QuantumCircuit.x "qiskit.circuit.QuantumCircuit.x") | [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate") | + | [`y()`](#qiskit.circuit.QuantumCircuit.y "qiskit.circuit.QuantumCircuit.y") | [`YGate`](qiskit.circuit.library.YGate "qiskit.circuit.library.YGate") | + | [`z()`](#qiskit.circuit.QuantumCircuit.z "qiskit.circuit.QuantumCircuit.z") | [`ZGate`](qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate") | + + The following methods apply [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") instances that are also controlled gates, so are direct subclasses of [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate"): + + | [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") method | [`qiskit.circuit.library`](circuit_library#module-qiskit.circuit.library "qiskit.circuit.library") [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") | + | ----------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | + | [`ccx()`](#qiskit.circuit.QuantumCircuit.ccx "qiskit.circuit.QuantumCircuit.ccx") | [`CCXGate`](qiskit.circuit.library.CCXGate "qiskit.circuit.library.CCXGate") | + | [`ccz()`](#qiskit.circuit.QuantumCircuit.ccz "qiskit.circuit.QuantumCircuit.ccz") | [`CCZGate`](qiskit.circuit.library.CCZGate "qiskit.circuit.library.CCZGate") | + | [`ch()`](#qiskit.circuit.QuantumCircuit.ch "qiskit.circuit.QuantumCircuit.ch") | [`CHGate`](qiskit.circuit.library.CHGate "qiskit.circuit.library.CHGate") | + | [`cp()`](#qiskit.circuit.QuantumCircuit.cp "qiskit.circuit.QuantumCircuit.cp") | [`CPhaseGate`](qiskit.circuit.library.CPhaseGate "qiskit.circuit.library.CPhaseGate") | + | [`crx()`](#qiskit.circuit.QuantumCircuit.crx "qiskit.circuit.QuantumCircuit.crx") | [`CRXGate`](qiskit.circuit.library.CRXGate "qiskit.circuit.library.CRXGate") | + | [`cry()`](#qiskit.circuit.QuantumCircuit.cry "qiskit.circuit.QuantumCircuit.cry") | [`CRYGate`](qiskit.circuit.library.CRYGate "qiskit.circuit.library.CRYGate") | + | [`crz()`](#qiskit.circuit.QuantumCircuit.crz "qiskit.circuit.QuantumCircuit.crz") | [`CRZGate`](qiskit.circuit.library.CRZGate "qiskit.circuit.library.CRZGate") | + | [`cs()`](#qiskit.circuit.QuantumCircuit.cs "qiskit.circuit.QuantumCircuit.cs") | [`CSGate`](qiskit.circuit.library.CSGate "qiskit.circuit.library.CSGate") | + | [`csdg()`](#qiskit.circuit.QuantumCircuit.csdg "qiskit.circuit.QuantumCircuit.csdg") | [`CSdgGate`](qiskit.circuit.library.CSdgGate "qiskit.circuit.library.CSdgGate") | + | [`cswap()`](#qiskit.circuit.QuantumCircuit.cswap "qiskit.circuit.QuantumCircuit.cswap") | [`CSwapGate`](qiskit.circuit.library.CSwapGate "qiskit.circuit.library.CSwapGate") | + | [`csx()`](#qiskit.circuit.QuantumCircuit.csx "qiskit.circuit.QuantumCircuit.csx") | [`CSXGate`](qiskit.circuit.library.CSXGate "qiskit.circuit.library.CSXGate") | + | [`cu()`](#qiskit.circuit.QuantumCircuit.cu "qiskit.circuit.QuantumCircuit.cu") | [`CUGate`](qiskit.circuit.library.CUGate "qiskit.circuit.library.CUGate") | + | [`cx()`](#qiskit.circuit.QuantumCircuit.cx "qiskit.circuit.QuantumCircuit.cx") | [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate") | + | [`cy()`](#qiskit.circuit.QuantumCircuit.cy "qiskit.circuit.QuantumCircuit.cy") | [`CYGate`](qiskit.circuit.library.CYGate "qiskit.circuit.library.CYGate") | + | [`cz()`](#qiskit.circuit.QuantumCircuit.cz "qiskit.circuit.QuantumCircuit.cz") | [`CZGate`](qiskit.circuit.library.CZGate "qiskit.circuit.library.CZGate") | + + Finally, these methods apply particular generalized multiply controlled gates to the circuit, often with eager syntheses. They are listed in terms of the *base* gate they are controlling, since their exact output is often a synthesised version of a gate. + + | [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") method | Base [`qiskit.circuit.library`](circuit_library#module-qiskit.circuit.library "qiskit.circuit.library") [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") | + | ----------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------- | + | [`mcp()`](#qiskit.circuit.QuantumCircuit.mcp "qiskit.circuit.QuantumCircuit.mcp") | [`PhaseGate`](qiskit.circuit.library.PhaseGate "qiskit.circuit.library.PhaseGate") | + | [`mcrx()`](#qiskit.circuit.QuantumCircuit.mcrx "qiskit.circuit.QuantumCircuit.mcrx") | [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate") | + | [`mcry()`](#qiskit.circuit.QuantumCircuit.mcry "qiskit.circuit.QuantumCircuit.mcry") | [`RYGate`](qiskit.circuit.library.RYGate "qiskit.circuit.library.RYGate") | + | [`mcrz()`](#qiskit.circuit.QuantumCircuit.mcrz "qiskit.circuit.QuantumCircuit.mcrz") | [`RZGate`](qiskit.circuit.library.RZGate "qiskit.circuit.library.RZGate") | + | [`mcx()`](#qiskit.circuit.QuantumCircuit.mcx "qiskit.circuit.QuantumCircuit.mcx") | [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate") | + + The rest of this section is the API listing of all the individual methods; the tables above are summaries whose links will jump you to the correct place. + + #### barrier + + + Apply `Barrier`. If `qargs` is empty, applies to all qubits in 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. + * **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** - a deepcopy of the current circuit, with the specified name + handle to the added instructions. **Return type** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + [qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### copy\_empty\_like - - - Return a copy of self with the same structure but empty. - - That structure includes: + #### ccx - * name, calibrations and other metadata - * global phase - * all the qubits and clbits, including the registers - * the realtime variables defined in the circuit, handled according to the `vars` keyword argument. + + Apply [`CCXGate`](qiskit.circuit.library.CCXGate "qiskit.circuit.library.CCXGate"). - - If the circuit contains any local variable declarations (those added by the `declarations` argument to the circuit constructor, or using [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var")), they may be **uninitialized** in the output circuit. You will need to manually add store instructions for them (see [`Store`](circuit#qiskit.circuit.Store "qiskit.circuit.Store") and [`QuantumCircuit.store()`](#qiskit.circuit.QuantumCircuit.store "qiskit.circuit.QuantumCircuit.store")) to initialize them. - + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - * **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name for the copied circuit. If None, then the name stays the same. + * **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. - * **vars\_mode** (*Literal\['alike', 'captures', 'drop']*) – + **Returns** - The mode to handle realtime variables in. + A handle to the instructions created. - **alike** + **Return type** - The variables in the output circuit will have the same declaration semantics as in the original circuit. For example, `input` variables in the source will be `input` variables in the output circuit. + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + - **captures** + #### ccz - All variables will be converted to captured variables. This is useful when you are building a new layer for an existing circuit that you will want to [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") onto the base, since [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") can inline captures onto the base circuit (but not other variables). + + Apply [`CCZGate`](qiskit.circuit.library.CCZGate "qiskit.circuit.library.CCZGate"). - **drop** + For the full matrix form of this gate, see the underlying gate documentation. - The output circuit will have no variables defined. + **Parameters** - **Returns** + * **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. - An empty copy of self. + **Returns** + + A handle to the instructions created. **Return type** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### count\_ops + #### ch - - Count each operation kind in the circuit. + + 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 breakdown of how many operations of each kind, sorted by amount. + A handle to the instructions created. **Return type** - OrderedDict + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### cp + #### cp - + Apply [`CPhaseGate`](qiskit.circuit.library.CPhaseGate "qiskit.circuit.library.CPhaseGate"). For the full matrix form of this gate, see the underlying gate documentation. @@ -965,9 +1497,9 @@ python_api_name: qiskit.circuit.QuantumCircuit [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### crx + #### crx - + Apply [`CRXGate`](qiskit.circuit.library.CRXGate "qiskit.circuit.library.CRXGate"). For the full matrix form of this gate, see the underlying gate documentation. @@ -989,9 +1521,9 @@ python_api_name: qiskit.circuit.QuantumCircuit [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### cry + #### cry - + Apply [`CRYGate`](qiskit.circuit.library.CRYGate "qiskit.circuit.library.CRYGate"). For the full matrix form of this gate, see the underlying gate documentation. @@ -1013,9 +1545,9 @@ python_api_name: qiskit.circuit.QuantumCircuit [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### crz + #### crz - + Apply [`CRZGate`](qiskit.circuit.library.CRZGate "qiskit.circuit.library.CRZGate"). For the full matrix form of this gate, see the underlying gate documentation. @@ -1037,9 +1569,9 @@ python_api_name: qiskit.circuit.QuantumCircuit [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### cs + #### cs - + Apply [`CSGate`](qiskit.circuit.library.CSGate "qiskit.circuit.library.CSGate"). For the full matrix form of this gate, see the underlying gate documentation. @@ -1060,9 +1592,9 @@ python_api_name: qiskit.circuit.QuantumCircuit [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### csdg + #### csdg - + Apply [`CSdgGate`](qiskit.circuit.library.CSdgGate "qiskit.circuit.library.CSdgGate"). For the full matrix form of this gate, see the underlying gate documentation. @@ -1083,9 +1615,9 @@ python_api_name: qiskit.circuit.QuantumCircuit [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### cswap + #### cswap - + Apply [`CSwapGate`](qiskit.circuit.library.CSwapGate "qiskit.circuit.library.CSwapGate"). For the full matrix form of this gate, see the underlying gate documentation. @@ -1107,9 +1639,9 @@ python_api_name: qiskit.circuit.QuantumCircuit [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### csx + #### csx - + Apply [`CSXGate`](qiskit.circuit.library.CSXGate "qiskit.circuit.library.CSXGate"). For the full matrix form of this gate, see the underlying gate documentation. @@ -1130,9 +1662,9 @@ python_api_name: qiskit.circuit.QuantumCircuit [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### cu + #### cu - + Apply [`CUGate`](qiskit.circuit.library.CUGate "qiskit.circuit.library.CUGate"). For the full matrix form of this gate, see the underlying gate documentation. @@ -1157,9 +1689,9 @@ python_api_name: qiskit.circuit.QuantumCircuit [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### cx + #### cx - + Apply [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate"). For the full matrix form of this gate, see the underlying gate documentation. @@ -1180,9 +1712,9 @@ python_api_name: qiskit.circuit.QuantumCircuit [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### cy + #### cy - + Apply [`CYGate`](qiskit.circuit.library.CYGate "qiskit.circuit.library.CYGate"). For the full matrix form of this gate, see the underlying gate documentation. @@ -1203,9 +1735,9 @@ python_api_name: qiskit.circuit.QuantumCircuit [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### cz + #### cz - + Apply [`CZGate`](qiskit.circuit.library.CZGate "qiskit.circuit.library.CZGate"). For the full matrix form of this gate, see the underlying gate documentation. @@ -1226,9 +1758,9 @@ python_api_name: qiskit.circuit.QuantumCircuit [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### dcx + #### dcx - + Apply [`DCXGate`](qiskit.circuit.library.DCXGate "qiskit.circuit.library.DCXGate"). For the full matrix form of this gate, see the underlying gate documentation. @@ -1247,28 +1779,9 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### decompose - - - 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 - + Apply [`Delay`](circuit#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** @@ -1290,130 +1803,160 @@ python_api_name: qiskit.circuit.QuantumCircuit [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if arguments have bad format. - ### depth + #### ecr - - Return circuit depth (i.e., length of critical path). + + Apply [`ECRGate`](qiskit.circuit.library.ECRGate "qiskit.circuit.library.ECRGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **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. + * **qubit1** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - Depth of circuit. + A handle to the instructions created. **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. + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### draw + #### h - - Draw the quantum circuit. Use the output parameter to choose the drawing format: + + Apply [`HGate`](qiskit.circuit.library.HGate "qiskit.circuit.library.HGate"). - **text**: ASCII art TextDrawing that can be printed in the console. + For the full matrix form of this gate, see the underlying gate documentation. - **mpl**: images with color rendered purely in Python using matplotlib. + **Parameters** - **latex**: high-quality images compiled via latex. + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. - **latex\_source**: raw uncompiled latex output. + **Returns** - - 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. - + A handle to the instructions created. - **Parameters** + **Return type** - * **output** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – 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. + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + - * **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Scale of image to draw (shrink if `< 1.0`). Only used by the `mpl`, `latex` and `latex_source` outputs. Defaults to `1.0`. + #### id - * **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – File path to save image to. Defaults to `None` (result not saved in a file). + + Apply [`IGate`](qiskit.circuit.library.IGate "qiskit.circuit.library.IGate"). - * **style** ([*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)") *| None*) – + For the full matrix form of this gate, see the underlying gate documentation. - Style name, file name of style JSON file, or a dictionary specifying the style. + **Parameters** - * The supported style names are `"iqp"` (default), `"iqp-dark"`, `"clifford"`, `"textbook"` and `"bw"`. - * If given a JSON file, e.g. `my_style.json` or `my_style` (the `.json` extension may be omitted), this function attempts to load the style dictionary from that location. Note, that the JSON file must completely specify the visualization specifications. The file is searched for in `qiskit/visualization/circuit/styles`, the current working directory, and the location specified in `~/.qiskit/settings.conf`. - * If a dictionary, every entry overrides the default configuration. If the `"name"` key is given, the default configuration is given by that style. For example, `{"name": "textbook", "subfontsize": 5}` loads the `"texbook"` style and sets the subfontsize (e.g. the gate angles) to `5`. - * If `None` the default style `"iqp"` is used or, if given, the default style specified in `~/.qiskit/settings.conf`. + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. - * **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`. + **Returns** - * **reverse\_bits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – 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`. + A handle to the instructions created. - * **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`. + **Return type** - * **justify** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – 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. + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + - * **vertical\_compression** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – `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. + #### initialize - * **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`. + + Initialize qubits in a specific state. - * **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`. + 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. - * **fold** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – 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. + **Parameters** - * **ax** (*Any | None*) – Only used by the mpl backend. An optional `matplotlib.axes.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. + * **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)")) – - * **initial\_state** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Adds $|0\rangle$ in the beginning of the qubit wires and $0$ to classical wires. Default is `False`. + The state to initialize to, can be either of the following. - * **cregbundle** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If set to `True`, bundle classical registers. Default is `True`, except for when `output` is set to `"text"`. + * 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$. - * **wire\_order** ([*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 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`). + * **qubits** (*Sequence\[QubitSpecifier] | None*) – Qubits to initialize. If `None` the initialization is applied to all qubits in the circuit. - * **expr\_len** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – 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. + * **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** - `TextDrawing` or `matplotlib.figure` or `PIL.Image` or [`str`](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"): + A handle to the instructions created. - * **`TextDrawing` (if `output='text'`)** + **Examples** - A drawing that can be printed as ascii art. + Prepare a qubit in the state $(|0\rangle - |1\rangle) / \sqrt{2}$. - * **`matplotlib.figure.Figure` (if `output='mpl'`)** + ```python + import numpy as np + from qiskit import QuantumCircuit - A matplotlib figure object for the circuit diagram. + circuit = QuantumCircuit(1) + circuit.initialize([1/np.sqrt(2), -1/np.sqrt(2)], 0) + circuit.draw() + ``` - * **`PIL.Image` (if `output='latex`’)** + output: - An in-memory representation of the image of the circuit diagram. + ```python + ┌──────────────────────────────┐ + q_0: ┤ Initialize(0.70711,-0.70711) ├ + └──────────────────────────────┘ + ``` - * **`str` (if `output='latex_source'`)** + 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"). - The LaTeX source code for visualizing the circuit diagram. + ```python + import numpy as np + from qiskit import QuantumCircuit - **Raises** + circuit = QuantumCircuit(2) + circuit.initialize('01', circuit.qubits) + circuit.draw() + ``` - * [**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. + output: - **Example** + ```python + ┌──────────────────┐ + q_0: ┤0 ├ + │ Initialize(0,1) │ + q_1: ┤1 ├ + └──────────────────┘ + ``` + + Initialize two qubits from an array of complex amplitudes. ```python - from qiskit import QuantumRegister, ClassicalRegister, QuantumCircuit - qc = QuantumCircuit(1, 1) - qc.h(0) - qc.measure(0, 0) - qc.draw(output='mpl', style={'backgroundcolor': '#EEEEEE'}) + 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() ``` - ![../\_images/qiskit-circuit-QuantumCircuit-5.png](/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-5.png) + output: + + ```python + ┌────────────────────────────────────┐ + q_0: ┤0 ├ + │ Initialize(0,0.70711,-0.70711j,0) │ + q_1: ┤1 ├ + └────────────────────────────────────┘ + ``` - ### ecr + #### iswap - - Apply [`ECRGate`](qiskit.circuit.library.ECRGate "qiskit.circuit.library.ECRGate"). + + Apply [`iSwapGate`](qiskit.circuit.library.iSwapGate "qiskit.circuit.library.iSwapGate"). For the full matrix form of this gate, see the underlying gate documentation. @@ -1431,289 +1974,367 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### find\_bit + #### mcp - - Find locations in the circuit which can be used to reference a given [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit"). + + Apply [`MCPhaseGate`](qiskit.circuit.library.MCPhaseGate "qiskit.circuit.library.MCPhaseGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - **bit** ([*Bit*](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit")) – The bit to locate. + * **lam** (*ParameterValueType*) – The angle of the rotation. + * **control\_qubits** (*Sequence\[QubitSpecifier]*) – The qubits used as the controls. + * **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 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`](circuit#qiskit.circuit.Register "qiskit.circuit.Register") in the circuit which contains the [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") (and the index in the [`Register`](circuit#qiskit.circuit.Register "qiskit.circuit.Register") at which it can be found). + A handle to the instructions created. **Return type** - namedtuple([int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"), List\[Tuple([Register](circuit#qiskit.circuit.Register "qiskit.circuit.Register"), [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"))]) + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + - **Notes** + #### mcrx - The circuit index of an [`AncillaQubit`](circuit#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"). + + Apply Multiple-Controlled X rotation gate - **Raises** + **Parameters** - * [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the supplied [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") was of an unknown type. - * [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the supplied [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") could not be found on the circuit. + * **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*](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*)*) – The list of control qubits + * **q\_target** ([*Qubit*](circuit#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 - **Return type** + **Raises** - *BitLocations* + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – parameter errors - ### for\_loop + #### mcry - - Create a `for` loop on this circuit. + + Apply Multiple-Controlled Y rotation gate - 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. + **Parameters** - For example: + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*)*) – The list of control qubits + * **q\_target** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")) – The target qubit + * **q\_ancillae** ([*QuantumRegister*](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*(*[*QuantumRegister*](circuit#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 - ```python - from qiskit import QuantumCircuit - qc = QuantumCircuit(2, 1) + **Raises** - 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) - ``` + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – parameter errors + - **Parameters** + #### mcrz - * **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. + + Apply Multiple-Controlled Z rotation gate - * **loop\_parameter** (*Optional\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*]*) – + **Parameters** - 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. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*)*) – The list of control qubits + * **q\_target** ([*Qubit*](circuit#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 - 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. + **Raises** - * **body** (*Optional\[*[*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The loop body to be repeatedly executed. Omit this to use the context-manager mode. + [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – parameter errors + - * **qubits** (*Optional\[Sequence\[QubitSpecifier]]*) – The circuit qubits over which the loop body should be run. Omit this to use the context-manager mode. + #### mcx - * **clbits** (*Optional\[Sequence\[ClbitSpecifier]]*) – The circuit clbits over which the loop body should be run. Omit this to use the context-manager mode. + + Apply [`MCXGate`](qiskit.circuit.library.MCXGate "qiskit.circuit.library.MCXGate"). - * **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. + 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: - **Returns** + * `'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). - 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. + For the full matrix form of this gate, see the underlying gate documentation. - **Return type** + **Parameters** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") or ForLoopContext + * **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. + * **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. **Raises** - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if an incorrect calling convention is used. + * [**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") - ### from\_instructions + #### measure + + + Measure a quantum bit (`qubit`) in the Z basis into a classical bit (`cbit`). - - Construct a circuit from an iterable of CircuitInstructions. + 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** - * **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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*], Iterable\[*[*Clbit*](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit")*]]]*) – The instructions to add to the circuit. - * **qubits** (*Iterable\[*[*Qubit*](circuit#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*](circuit#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. + * **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Clbit "qiskit.circuit.classicalregister.Clbit") *|*[*ClassicalRegister*](circuit#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*](circuit#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** - The quantum circuit. + handle to the added instructions. **Return type** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - + [qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### from\_qasm\_file + **Raises** - - Read an OpenQASM 2.0 program from a file and convert to an instance of [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if arguments have bad format. - **Parameters** + **Examples** - **path** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Path to the file for an OpenQASM 2 program + 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): - **Returns** + ```python + from qiskit import QuantumCircuit + circuit = QuantumCircuit(1, 1) + circuit.h(0) + circuit.measure(0, 0) + circuit.draw() + ``` - The QuantumCircuit object for the input OpenQASM 2. + ```python + ┌───┐┌─┐ + q: ┤ H ├┤M├ + └───┘└╥┘ + c: 1/══════╩═ + 0 + ``` - **Return type** + 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: - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + ```python + circuit = QuantumCircuit(2, 2) + circuit.measure([0,1], [0,1]) + ``` - - [`qasm2.load()`](qasm2#qiskit.qasm2.load "qiskit.qasm2.load"): the complete interface to the OpenQASM 2 importer. - + ```python + circuit = QuantumCircuit(2, 2) + circuit.measure(0, 0) + circuit.measure(1, 1) + ``` + + Instead of lists, you can use [`QuantumRegister`](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") and [`ClassicalRegister`](circuit#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]) + ``` - ### from\_qasm\_str + #### ms - - Convert a string containing an OpenQASM 2.0 program to a [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + + Apply [`MSGate`](qiskit.circuit.library.MSGate "qiskit.circuit.library.MSGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **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. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - The QuantumCircuit object for the input OpenQASM 2 + A handle to the instructions created. **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. - + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### get\_instructions + #### p - - Get instructions matching name. + + Apply [`PhaseGate`](qiskit.circuit.library.PhaseGate "qiskit.circuit.library.PhaseGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of instruction to. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - list of (instruction, qargs, cargs). + A handle to the instructions created. **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)")) + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### get\_parameter + #### pauli - - Retrieve a compile-time parameter that is accessible in this circuit scope by name. + + Apply [`PauliGate`](qiskit.circuit.library.PauliGate "qiskit.circuit.library.PauliGate"). **Parameters** - * **name** – the name of the parameter to retrieve. - * **default** – if given, this value will be returned if the parameter is not present. If it is not given, a [`KeyError`](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") is raised instead. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - The corresponding parameter. + A handle to the instructions created. - **Raises** + **Return type** - [**KeyError**](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") – if no default is given, but the parameter does not exist in the circuit. + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + - **Examples** + #### prepare\_state - Retrieve a parameter by name from a circuit: + + Prepare qubits in a specific state. - ```python - from qiskit.circuit import QuantumCircuit, Parameter + This class implements a state preparing unitary. Unlike [`initialize()`](#qiskit.circuit.QuantumCircuit.initialize "qiskit.circuit.QuantumCircuit.initialize") it does not reset the qubits first. - my_param = Parameter("my_param") + **Parameters** - # Create a parametrised circuit. - qc = QuantumCircuit(1) - qc.rx(my_param, 0) + * **state** ([*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)")) – - # We can use 'my_param' as a parameter, but let's say we've lost the Python object - # and need to retrieve it. - my_param_again = qc.get_parameter("my_param") + The state to initialize to, can be either of the following. - assert my_param is my_param_again - ``` + * 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$. - Get a variable from a circuit by name, returning some default if it is not present: + * **qubits** (*Sequence\[QubitSpecifier] | None*) – Qubits to initialize. If `None` the initialization is applied to all qubits in the circuit. - ```python - assert qc.get_parameter("my_param", None) is my_param - assert qc.get_parameter("unknown_param", None) is None - ``` + * **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – An optional label for the gate - - **[`get_var()`](#qiskit.circuit.QuantumCircuit.get_var "qiskit.circuit.QuantumCircuit.get_var")** + * **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. - A similar method, but for [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") run-time variables instead of [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") compile-time parameters. - - + **Returns** - ### get\_var + A handle to the instruction that was just initialized - - Retrieve a variable that is accessible in this circuit scope by name. + **Return type** - **Parameters** + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - * **name** – the name of the variable to retrieve. - * **default** – if given, this value will be returned if the variable is not present. If it is not given, a [`KeyError`](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") is raised instead. + **Examples** - **Returns** + Prepare a qubit in the state $(|0\rangle - |1\rangle) / \sqrt{2}$. - The corresponding variable. + ```python + import numpy as np + from qiskit import QuantumCircuit - **Raises** + circuit = QuantumCircuit(1) + circuit.prepare_state([1/np.sqrt(2), -1/np.sqrt(2)], 0) + circuit.draw() + ``` - [**KeyError**](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") – if no default is given, but the variable does not exist. + output: - **Examples** + ```python + ┌─────────────────────────────────────┐ + q_0: ┤ State Preparation(0.70711,-0.70711) ├ + └─────────────────────────────────────┘ + ``` - Retrieve a variable by name from a circuit: + 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 - from qiskit.circuit import QuantumCircuit + import numpy as np + from qiskit import QuantumCircuit - # Create a circuit and create a variable in it. - qc = QuantumCircuit() - my_var = qc.add_var("my_var", False) + circuit = QuantumCircuit(2) + circuit.prepare_state('01', circuit.qubits) + circuit.draw() + ``` - # We can use 'my_var' as a variable, but let's say we've lost the Python object and - # need to retrieve it. - my_var_again = qc.get_var("my_var") + output: - assert my_var is my_var_again + ```python + ┌─────────────────────────┐ + q_0: ┤0 ├ + │ State Preparation(0,1) │ + q_1: ┤1 ├ + └─────────────────────────┘ ``` - Get a variable from a circuit by name, returning some default if it is not present: + Initialize two qubits from an array of complex amplitudes .. code-block: ```python - assert qc.get_var("my_var", None) is my_var - assert qc.get_var("unknown_variable", None) is None + 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() ``` - - **[`get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter")** + output: - A similar method, but for [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") compile-time parameters instead of [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") run-time variables. - + ```python + ┌───────────────────────────────────────────┐ + q_0: ┤0 ├ + │ State Preparation(0,0.70711,-0.70711j,0) │ + q_1: ┤1 ├ + └───────────────────────────────────────────┘ + ``` - ### h + #### r - - Apply [`HGate`](qiskit.circuit.library.HGate "qiskit.circuit.library.HGate"). + + Apply [`RGate`](qiskit.circuit.library.RGate "qiskit.circuit.library.RGate"). For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. @@ -1722,96 +2343,84 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### has\_calibration\_for - - - 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. - + #### rcccx - ### has\_parameter + + Apply [`RC3XGate`](qiskit.circuit.library.RC3XGate "qiskit.circuit.library.RC3XGate"). - - Check whether a parameter object exists in this circuit. + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - **name\_or\_param** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")) – the parameter, or name of a parameter to check. If this is a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") node, the parameter must be exactly the given one for this function to return `True`. + * **control\_qubit1** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - whether a matching parameter is assignable in this circuit. + A handle to the instructions created. **Return type** - [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") - - - **[`QuantumCircuit.get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter")** - - Retrieve the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instance from this circuit by name. - - **[`QuantumCircuit.has_var()`](#qiskit.circuit.QuantumCircuit.has_var "qiskit.circuit.QuantumCircuit.has_var")** - - A similar method to this, but for run-time [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") variables instead of compile-time [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")s. - + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### has\_register + #### rccx - - Test if this circuit has the register r. + + Apply [`RCCXGate`](qiskit.circuit.library.RCCXGate "qiskit.circuit.library.RCCXGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - **register** ([*Register*](circuit#qiskit.circuit.Register "qiskit.circuit.Register")) – a quantum or classical register. + * **control\_qubit1** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - True if the register is contained in this circuit. + A handle to the instructions created. **Return type** - [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### has\_var + #### reset - - Check whether a variable is accessible in this scope. + + Reset the quantum bit(s) to their default state. **Parameters** - **name\_or\_var** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")) – the variable, or name of a variable to check. If this is a [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node, the variable must be exactly the given one for this function to return `True`. + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - whether a matching variable is accessible. + handle to the added instruction. **Return type** - [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") - - - **[`QuantumCircuit.get_var()`](#qiskit.circuit.QuantumCircuit.get_var "qiskit.circuit.QuantumCircuit.get_var")** - - Retrieve the [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instance from this circuit by name. - - **[`QuantumCircuit.has_parameter()`](#qiskit.circuit.QuantumCircuit.has_parameter "qiskit.circuit.QuantumCircuit.has_parameter")** - - A similar method to this, but for compile-time [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")s instead of run-time [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") variables. - + [qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### id + #### rv - - Apply [`IGate`](qiskit.circuit.library.IGate "qiskit.circuit.library.IGate"). + + 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** - **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -1822,250 +2431,169 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### if\_else - - - Apply [`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp"). + #### rx - - 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: + + Apply [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"). - ```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) - ``` - + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - * **condition** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*ClassicalRegister*](circuit#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*](circuit#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*](circuit#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 in real time at circuit execution, 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. + * **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 instruction created. + A handle to the instructions created. **Return type** [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### if\_test - - - 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) + #### rxx - qc.h(0) - qc.cx(0, 1) - qc.measure(0, 0) - qc.h(0) - qc.cx(0, 1) - qc.measure(0, 1) + + Apply [`RXXGate`](qiskit.circuit.library.RXXGate "qiskit.circuit.library.RXXGate"). - with qc.if_test((bits[3], 0)) as else_: - qc.x(2) - with else_: - qc.h(2) - qc.z(2) - ``` + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - * **condition** (*Tuple\[Union\[*[*ClassicalRegister*](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")*,* [*Clbit*](circuit#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 in real time during circuit execution, 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. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - 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. + A handle to the instructions created. **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. + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### initialize + #### ry - - Initialize qubits in a specific state. + + Apply [`RYGate`](qiskit.circuit.library.RYGate "qiskit.circuit.library.RYGate"). - 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. + For the full matrix form of this gate, see the underlying gate documentation. **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)")) – + * **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. - The state to initialize to, can be either of the following. + **Returns** - * 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$. + A handle to the instructions created. - * **qubits** (*Sequence\[QubitSpecifier] | None*) – Qubits to initialize. If `None` the initialization is applied to all qubits in the circuit. + **Return type** - * **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. + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + - **Returns** + #### ryy - A handle to the instructions created. + + Apply [`RYYGate`](qiskit.circuit.library.RYYGate "qiskit.circuit.library.RYYGate"). - **Examples** + For the full matrix form of this gate, see the underlying gate documentation. - Prepare a qubit in the state $(|0\rangle - |1\rangle) / \sqrt{2}$. + **Parameters** - ```python - import numpy as np - from qiskit import QuantumCircuit + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. - circuit = QuantumCircuit(1) - circuit.initialize([1/np.sqrt(2), -1/np.sqrt(2)], 0) - circuit.draw() - ``` + **Returns** - output: + A handle to the instructions created. - ```python - ┌──────────────────────────────┐ - q_0: ┤ Initialize(0.70711,-0.70711) ├ - └──────────────────────────────┘ - ``` + **Return type** - 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"). + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + - ```python - import numpy as np - from qiskit import QuantumCircuit + #### rz - circuit = QuantumCircuit(2) - circuit.initialize('01', circuit.qubits) - circuit.draw() - ``` + + Apply [`RZGate`](qiskit.circuit.library.RZGate "qiskit.circuit.library.RZGate"). - output: + For the full matrix form of this gate, see the underlying gate documentation. - ```python - ┌──────────────────┐ - q_0: ┤0 ├ - │ Initialize(0,1) │ - q_1: ┤1 ├ - └──────────────────┘ - ``` + **Parameters** - Initialize two qubits from an array of complex amplitudes. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. - ```python - import numpy as np - from qiskit import QuantumCircuit + **Returns** - circuit = QuantumCircuit(2) - circuit.initialize([0, 1/np.sqrt(2), -1.j/np.sqrt(2), 0], circuit.qubits) - circuit.draw() - ``` + A handle to the instructions created. - output: + **Return type** - ```python - ┌────────────────────────────────────┐ - q_0: ┤0 ├ - │ Initialize(0,0.70711,-0.70711j,0) │ - q_1: ┤1 ├ - └────────────────────────────────────┘ - ``` + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### inverse + #### rzx - - Invert (take adjoint of) this circuit. + + Apply [`RZXGate`](qiskit.circuit.library.RZXGate "qiskit.circuit.library.RZXGate"). - This is done by recursively inverting all gates. + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the inverse gate can be implemented as an annotated gate. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - the inverted circuit + A handle to the instructions created. **Return type** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + - **Raises** + #### rzz - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the circuit cannot be inverted. + + Apply [`RZZGate`](qiskit.circuit.library.RZZGate "qiskit.circuit.library.RZZGate"). - **Examples** + For the full matrix form of this gate, see the underlying gate documentation. - input: + **Parameters** - ```python - ┌───┐ - q_0: ┤ H ├─────■────── - └───┘┌────┴─────┐ - q_1: ─────┤ RX(1.57) ├ - └──────────┘ - ``` + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. - output: + **Returns** - ```python - ┌───┐ - q_0: ──────■──────┤ H ├ - ┌─────┴─────┐└───┘ - q_1: ┤ RX(-1.57) ├───── - └───────────┘ - ``` + A handle to the instructions created. + + **Return type** + + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### iswap + #### s - - Apply [`iSwapGate`](qiskit.circuit.library.iSwapGate "qiskit.circuit.library.iSwapGate"). + + Apply [`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate"). For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - * **qubit1** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -2076,61 +2604,64 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### iter\_captured\_vars + #### sdg - - Get an iterable over all real-time classical variables that are captured by this circuit scope from a containing scope. This excludes input variables (see [`iter_input_vars()`](#qiskit.circuit.QuantumCircuit.iter_input_vars "qiskit.circuit.QuantumCircuit.iter_input_vars")) and locally declared variables (see [`iter_declared_vars()`](#qiskit.circuit.QuantumCircuit.iter_declared_vars "qiskit.circuit.QuantumCircuit.iter_declared_vars")). + + Apply [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate"). - **Return type** + For the full matrix form of this gate, see the underlying gate documentation. - [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")] - + **Parameters** - ### iter\_declared\_vars + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. - - Get an iterable over all real-time classical variables that are declared with automatic storage duration in this scope. This excludes input variables (see [`iter_input_vars()`](#qiskit.circuit.QuantumCircuit.iter_input_vars "qiskit.circuit.QuantumCircuit.iter_input_vars")) and captured variables (see [`iter_captured_vars()`](#qiskit.circuit.QuantumCircuit.iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars")). + **Returns** + + A handle to the instructions created. **Return type** - [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")] + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### iter\_input\_vars + #### store - - Get an iterable over all real-time classical variables that are declared as inputs to this circuit scope. This excludes locally declared variables (see [`iter_declared_vars()`](#qiskit.circuit.QuantumCircuit.iter_declared_vars "qiskit.circuit.QuantumCircuit.iter_declared_vars")) and captured variables (see [`iter_captured_vars()`](#qiskit.circuit.QuantumCircuit.iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars")). + + Store the result of the given real-time classical expression `rvalue` in the memory location defined by `lvalue`. - **Return type** + Typically `lvalue` will be a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node and `rvalue` will be some [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") to write into it, but anything that [`expr.lift()`](circuit_classical#qiskit.circuit.classical.expr.lift "qiskit.circuit.classical.expr.lift") can raise to an [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") is permissible in both places, and it will be called on them. - [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")] - + **Parameters** - ### iter\_vars + * **lvalue** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – a valid specifier for a memory location in the circuit. This will typically be a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node, but you can also write to [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") or [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") memory locations if your hardware supports it. The memory location must already be present in the circuit. + * **rvalue** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – a real-time classical expression whose result should be written into the given memory location. - - Get an iterable over all real-time classical variables in scope within this circuit. + **Return type** - This method will iterate over all variables in scope. For more fine-grained iterators, see [`iter_declared_vars()`](#qiskit.circuit.QuantumCircuit.iter_declared_vars "qiskit.circuit.QuantumCircuit.iter_declared_vars"), [`iter_input_vars()`](#qiskit.circuit.QuantumCircuit.iter_input_vars "qiskit.circuit.QuantumCircuit.iter_input_vars") and [`iter_captured_vars()`](#qiskit.circuit.QuantumCircuit.iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars"). + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - **Return type** + + **[`Store`](circuit#qiskit.circuit.Store "qiskit.circuit.Store")** - [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")] + The backing [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") class that represents this operation. + + **[`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var")** + + Create a new variable in the circuit that can be written to with this method. + - ### mcp + #### swap - - Apply [`MCPhaseGate`](qiskit.circuit.library.MCPhaseGate "qiskit.circuit.library.MCPhaseGate"). + + Apply [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate"). For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - * **lam** (*ParameterValueType*) – The angle of the rotation. - * **control\_qubits** (*Sequence\[QubitSpecifier]*) – The qubits used as the controls. - * **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. + * **qubit1** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -2138,235 +2669,197 @@ python_api_name: qiskit.circuit.QuantumCircuit **Return type** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### mcrx + #### sx - - Apply Multiple-Controlled X rotation gate + + Apply [`SXGate`](qiskit.circuit.library.SXGate "qiskit.circuit.library.SXGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **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*](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*)*) – The list of control qubits - * **q\_target** ([*Qubit*](circuit#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 + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. - **Raises** + **Returns** - [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – parameter errors + A handle to the instructions created. + + **Return type** + + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### mcry + #### sxdg - - Apply Multiple-Controlled Y rotation gate + + Apply [`SXdgGate`](qiskit.circuit.library.SXdgGate "qiskit.circuit.library.SXdgGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*)*) – The list of control qubits - * **q\_target** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")) – The target qubit - * **q\_ancillae** ([*QuantumRegister*](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*(*[*QuantumRegister*](circuit#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 + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. - **Raises** + **Returns** - [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – parameter errors + A handle to the instructions created. + + **Return type** + + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### mcrz + #### t - - Apply Multiple-Controlled Z rotation gate + + Apply [`TGate`](qiskit.circuit.library.TGate "qiskit.circuit.library.TGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*)*) – The list of control qubits - * **q\_target** ([*Qubit*](circuit#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 + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. - **Raises** + **Returns** - [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – parameter errors - + A handle to the instructions created. - ### mcx + **Return type** - - Apply [`MCXGate`](qiskit.circuit.library.MCXGate "qiskit.circuit.library.MCXGate"). + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + - 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: + #### tdg - * `'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). + + Apply [`TdgGate`](qiskit.circuit.library.TdgGate "qiskit.circuit.library.TdgGate"). 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. - * **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. + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. - **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") + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### measure + #### u - - Measure a quantum bit (`qubit`) in the Z basis into a classical bit (`cbit`). + + Apply [`UGate`](qiskit.circuit.library.UGate "qiskit.circuit.library.UGate"). - 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. + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - * **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Clbit "qiskit.circuit.classicalregister.Clbit") *|*[*ClassicalRegister*](circuit#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*](circuit#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. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - handle to the added instructions. + A handle to the instructions created. **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. + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + - **Examples** + #### unitary - 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): + + Apply unitary gate specified by `obj` to `qubits`. - ```python - from qiskit import QuantumCircuit - circuit = QuantumCircuit(1, 1) - circuit.h(0) - circuit.measure(0, 0) - circuit.draw() - ``` + **Parameters** - ```python - ┌───┐┌─┐ - q: ┤ H ├┤M├ - └───┘└╥┘ - c: 1/══════╩═ - 0 - ``` + * **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]. - 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: + **Returns** - ```python - circuit = QuantumCircuit(2, 2) - circuit.measure([0,1], [0,1]) - ``` + The quantum circuit. - ```python - circuit = QuantumCircuit(2, 2) - circuit.measure(0, 0) - circuit.measure(1, 1) - ``` + **Return type** - Instead of lists, you can use [`QuantumRegister`](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") and [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") under the same logic. + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ```python - from qiskit import QuantumCircuit, QuantumRegister, ClassicalRegister - qreg = QuantumRegister(2, "qreg") - creg = ClassicalRegister(2, "creg") - circuit = QuantumCircuit(qreg, creg) - circuit.measure(qreg, creg) - ``` + **Example** - This is equivalent to: + Apply a gate specified by a unitary matrix to a quantum circuit ```python - circuit = QuantumCircuit(qreg, creg) - circuit.measure(qreg[0], creg[0]) - circuit.measure(qreg[1], creg[1]) + 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]) ``` - ### measure\_active + #### x - - Adds measurement to all non-idle qubits. Creates a new ClassicalRegister with a size equal to the number of non-idle qubits being measured. + + Apply [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate"). - Returns a new circuit with measurements if inplace=False. + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – All measurements inplace or return new circuit. + * **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** - Returns circuit with measurements when inplace = False. + A handle to the instructions created. **Return type** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### measure\_all + #### y - - Adds measurement to all qubits. - - By default, adds new classical bits in a [`ClassicalRegister`](circuit#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`. + + Apply [`YGate`](qiskit.circuit.library.YGate "qiskit.circuit.library.YGate"). - Returns a new circuit with measurements if `inplace=False`. + For the full matrix form of this gate, see the underlying gate documentation. **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. + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - Returns circuit with measurements when `inplace=False`. + A handle to the instructions created. **Return type** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + - **Raises** + #### z - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `add_bits=False` but there are not enough classical bits. - - - ### ms - - - Apply [`MSGate`](qiskit.circuit.library.MSGate "qiskit.circuit.library.MSGate"). + + Apply [`ZGate`](qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate"). 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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -2377,1187 +2870,1214 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### num\_connected\_components - - - 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)") - + ### Adding control flow to circuits - ### num\_nonlocal\_gates + + [Control flow in circuits](circuit#circuit-control-flow-repr) - - Return number of non-local gates (i.e. involving 2+ qubits). + Discussion of how control-flow operations are represented in the whole [`qiskit.circuit`](circuit#module-qiskit.circuit "qiskit.circuit") context. + - Conditional nonlocal gates are also included. - - **Return type** + | [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") method | Control-flow instruction | + | --------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------- | + | [`if_test()`](#qiskit.circuit.QuantumCircuit.if_test "qiskit.circuit.QuantumCircuit.if_test") | [`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp") with only a `True` body. | + | [`if_else()`](#qiskit.circuit.QuantumCircuit.if_else "qiskit.circuit.QuantumCircuit.if_else") | [`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp") with both `True` and `False` bodies. | + | [`while_loop()`](#qiskit.circuit.QuantumCircuit.while_loop "qiskit.circuit.QuantumCircuit.while_loop") | [`WhileLoopOp`](qiskit.circuit.WhileLoopOp "qiskit.circuit.WhileLoopOp"). | + | [`switch()`](#qiskit.circuit.QuantumCircuit.switch "qiskit.circuit.QuantumCircuit.switch") | [`SwitchCaseOp`](qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp"). | + | [`for_loop()`](#qiskit.circuit.QuantumCircuit.for_loop "qiskit.circuit.QuantumCircuit.for_loop") | [`ForLoopOp`](qiskit.circuit.ForLoopOp "qiskit.circuit.ForLoopOp"). | + | [`break_loop()`](#qiskit.circuit.QuantumCircuit.break_loop "qiskit.circuit.QuantumCircuit.break_loop") | [`BreakLoopOp`](qiskit.circuit.BreakLoopOp "qiskit.circuit.BreakLoopOp"). | + | [`continue_loop()`](#qiskit.circuit.QuantumCircuit.continue_loop "qiskit.circuit.QuantumCircuit.continue_loop") | [`ContinueLoopOp`](qiskit.circuit.ContinueLoopOp "qiskit.circuit.ContinueLoopOp"). | - [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") - + [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") has corresponding methods for all of the control-flow operations that are supported by Qiskit. These have two forms for calling them. The first is a very straightfowards convenience wrapper that takes in the block bodies of the instructions as [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") arguments, and simply constructs and appends the corresponding [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp"). - ### num\_tensor\_factors + The second form, which we strongly recommend you use for constructing control flow, is called *the builder interface*. Here, the methods take only the real-time discriminant of the operation, and return [context managers](https://docs.python.org/3/library/stdtypes.html#typecontextmanager) that you enter using `with`. You can then use regular [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") methods within those blocks to build up the control-flow bodies, and Qiskit will automatically track which of the data resources are needed for the inner blocks, building the complete [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") as you leave the `with` statement. It is far simpler and less error-prone to build control flow programmatically this way. - - Computes the number of tensor factors in the unitary (quantum) part of the circuit only. + #### break\_loop - **Notes** + + Apply [`BreakLoopOp`](qiskit.circuit.BreakLoopOp "qiskit.circuit.BreakLoopOp"). - This is here for backwards compatibility, and will be removed in a future release of Qiskit. You should call num\_unitary\_factors instead. + + 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. + - **Return type** + **Returns** - [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") - + A handle to the instruction created. - ### num\_unitary\_factors + **Raises** - - Computes the number of tensor factors in the unitary (quantum) part of the circuit only. + [**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** - [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### p + #### continue\_loop - - Apply [`PhaseGate`](qiskit.circuit.library.PhaseGate "qiskit.circuit.library.PhaseGate"). + + Apply [`ContinueLoopOp`](qiskit.circuit.ContinueLoopOp "qiskit.circuit.ContinueLoopOp"). - For the full matrix form of this gate, see the underlying gate documentation. + + 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. + - **Parameters** + **Returns** - * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + A handle to the instruction created. - **Returns** + **Raises** - A handle to the instructions created. + [**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") - ### pauli + #### for\_loop - - Apply [`PauliGate`](qiskit.circuit.library.PauliGate "qiskit.circuit.library.PauliGate"). + + Create a `for` loop on this circuit. - **Parameters** + 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. - * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + For example: - **Returns** + ```python + from qiskit import QuantumCircuit + qc = QuantumCircuit(2, 1) - A handle to the instructions created. + 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) + ``` - **Return type** + **Parameters** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - + * **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. - ### power + * **loop\_parameter** (*Optional\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*]*) – - - Raise this circuit to the power of `power`. + 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 `power` is a positive integer and both `matrix_power` and `annotated` are `False`, this implementation defaults to calling `repeat`. Otherwise, the circuit is converted into a gate, and a new circuit, containing this gate raised to the given power, is returned. The gate raised to the given power is implemented either as a unitary gate if `annotated` is `False` or as an annotated operation if `annotated` is `True`. + 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. - **Parameters** + * **body** (*Optional\[*[*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The loop body to be repeatedly executed. Omit this to use the context-manager mode. - * **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)")) – indicates whether the inner power gate can be implemented as a unitary gate. - * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the inner power gate can be implemented as an annotated operation. + * **qubits** (*Optional\[Sequence\[QubitSpecifier]]*) – The circuit qubits over which the loop body should be run. Omit this to use the context-manager mode. - **Raises** + * **clbits** (*Optional\[Sequence\[ClbitSpecifier]]*) – The circuit clbits over which the loop body should be run. Omit this to use the context-manager mode. - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the circuit needs to be converted to a unitary gate, but is not unitary. + * **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** - A circuit implementing this circuit raised to the power of `power`. + 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** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") or ForLoopContext - ### prepare\_state + **Raises** - - Prepare qubits in a specific state. + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if an incorrect calling convention is used. + - This class implements a state preparing unitary. Unlike [`initialize()`](#qiskit.circuit.QuantumCircuit.initialize "qiskit.circuit.QuantumCircuit.initialize") it does not reset the qubits first. + #### if\_else - **Parameters** + + Apply [`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp"). - * **state** ([*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)")) – + + 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: - The state to initialize to, can be either of the following. + ```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) + ``` + - * 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$. + **Parameters** - * **qubits** (*Sequence\[QubitSpecifier] | None*) – Qubits to initialize. If `None` the initialization is applied to all qubits in the circuit. + * **condition** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*ClassicalRegister*](circuit#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*](circuit#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*](circuit#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 in real time at circuit execution, 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. - * **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – An optional label for the gate + **Raises** - * **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. + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the provided condition references Clbits outside the enclosing circuit. **Returns** - A handle to the instruction that was just initialized + A handle to the instruction created. **Return type** [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + - **Examples** - - Prepare a qubit in the state $(|0\rangle - |1\rangle) / \sqrt{2}$. + #### if\_test - ```python - import numpy as np - from qiskit import QuantumCircuit + + Create an `if` statement on this circuit. - circuit = QuantumCircuit(1) - circuit.prepare_state([1/np.sqrt(2), -1/np.sqrt(2)], 0) - circuit.draw() - ``` + 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. - output: + For example: ```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"). + from qiskit.circuit import QuantumCircuit, Qubit, Clbit + bits = [Qubit(), Qubit(), Qubit(), Clbit(), Clbit()] + qc = QuantumCircuit(bits) - ```python - import numpy as np - from qiskit import QuantumCircuit + qc.h(0) + qc.cx(0, 1) + qc.measure(0, 0) + qc.h(0) + qc.cx(0, 1) + qc.measure(0, 1) - circuit = QuantumCircuit(2) - circuit.prepare_state('01', circuit.qubits) - circuit.draw() + with qc.if_test((bits[3], 0)) as else_: + qc.x(2) + with else_: + qc.h(2) + qc.z(2) ``` - output: - - ```python - ┌─────────────────────────┐ - q_0: ┤0 ├ - │ State Preparation(0,1) │ - q_1: ┤1 ├ - └─────────────────────────┘ - ``` + **Parameters** - Initialize two qubits from an array of complex amplitudes .. code-block: + * **condition** (*Tuple\[Union\[*[*ClassicalRegister*](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")*,* [*Clbit*](circuit#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 in real time during circuit execution, 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. - ```python - import numpy as np - from qiskit import QuantumCircuit + **Returns** - circuit = QuantumCircuit(2) - circuit.prepare_state([0, 1/np.sqrt(2), -1.j/np.sqrt(2), 0], circuit.qubits) - circuit.draw() - ``` + 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. - output: + **Return type** - ```python - ┌───────────────────────────────────────────┐ - q_0: ┤0 ├ - │ State Preparation(0,0.70711,-0.70711j,0) │ - q_1: ┤1 ├ - └───────────────────────────────────────────┘ - ``` - + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") or IfContext - ### qbit\_argument\_conversion + **Raises** - - Converts several qubit representations (such as indexes, range, etc.) into a list of qubits. + * [**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. - **Parameters** + **Returns** - **qubit\_representation** (*Object*) – representation to expand + A handle to the instruction created. + - **Returns** + #### switch - the resolved instances of the qubits. + + Create a `switch`/`case` structure on this circuit. - **Return type** + 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. - List([Qubit](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")) - + Example usage: - ### qubit\_duration + ```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]) - - 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`. + 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** - **\*qubits** ([*Qubit*](circuit#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. + * **target** (*Union\[*[*ClassicalRegister*](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")*,* [*Clbit*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – The circuit qubits over which all case bodies execute. Omit in context-manager form. + * **clbits** (*Sequence\[*[*Clbit*](circuit#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** - Return the duration between the first start and last stop time of non-delay instructions + 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** - [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + [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. - ### qubit\_start\_time + #### while\_loop - - Return the start time of the first instruction, excluding delays, over the supplied qubits. Its time unit is `self.unit`. + + Create a `while` loop on this circuit. - Return 0 if there are no instructions over qubits + 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** - * **\*qubits** ([*Qubit*](circuit#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*) – + * **condition** (*Tuple\[Union\[*[*ClassicalRegister*](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")*,* [*Clbit*](circuit#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`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") or a [`Clbit`](circuit#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*](circuit#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*](circuit#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** - Return the start time of the first instruction, excluding delays, over the qubits + 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. - **Raises** + **Return type** - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `self` is a not-yet scheduled circuit. + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") or WhileLoopContext - **Return type** + **Raises** - [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if an incorrect calling convention is used. - ### qubit\_stop\_time + ### Converting circuits to single objects - - Return the stop time of the last instruction, excluding delays, over the supplied qubits. Its time unit is `self.unit`. + As discussed in [Methods to add general operations](#circuit-append-compose), you can convert a circuit to either an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") or a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") using two helper methods. - Return 0 if there are no instructions over qubits + #### to\_instruction + + + Create an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") out of this circuit. + + + **`circuit_to_instruction()`** + + The underlying driver of this method. + **Parameters** - * **\*qubits** ([*Qubit*](circuit#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*) – + * **parameter\_map** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*, ParameterValueType] | None*) – 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)") *| None*) – Optional gate label. **Returns** - Return the stop time of the last instruction, excluding delays, over the qubits - - **Raises** + **a composite instruction encapsulating this circuit (can be** - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `self` is a not-yet scheduled circuit. + decomposed back). **Return type** - [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + [qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") - ### r + #### to\_gate - - Apply [`RGate`](qiskit.circuit.library.RGate "qiskit.circuit.library.RGate"). + + Create a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") out of this circuit. The circuit must act only qubits and contain only unitary operations. - For the full matrix form of this gate, see the underlying gate documentation. + + **`circuit_to_gate()`** + + The underlying driver of this method. + **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + * **parameter\_map** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*, ParameterValueType] | None*) – 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)") *| None*) – Optional gate label. **Returns** - A handle to the instructions created. + a composite gate encapsulating this circuit (can be decomposed back). **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [Gate](qiskit.circuit.Gate "qiskit.circuit.Gate") - ### rcccx + ### Helper mutation methods - - Apply [`RC3XGate`](qiskit.circuit.library.RC3XGate "qiskit.circuit.library.RC3XGate"). + There are two higher-level methods on [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") for appending measurements to the end of a circuit. Note that by default, these also add an extra register. - For the full matrix form of this gate, see the underlying gate documentation. + #### measure\_active + + + 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** - * **control\_qubit1** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – All measurements inplace or return new circuit. **Returns** - A handle to the instructions created. + Returns circuit with measurements when inplace = False. **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ### rccx + #### measure\_all - - Apply [`RCCXGate`](qiskit.circuit.library.RCCXGate "qiskit.circuit.library.RCCXGate"). + + Adds measurement to all qubits. - For the full matrix form of this gate, see the underlying gate documentation. + By default, adds new classical bits in a [`ClassicalRegister`](circuit#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** - * **control\_qubit1** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + * **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** - A handle to the instructions created. + Returns circuit with measurements when `inplace=False`. **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - - - ### remove\_final\_measurements + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - - 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. + **Raises** - Measurements and barriers are considered final if they are followed by no other operations (aside from other measurements or barriers.) + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `add_bits=False` but there are not enough classical bits. + - **Parameters** + There are two “subtractive” methods on [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") as well. This is not a use-case that [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") is designed for; typically you should just look to use [`copy_empty_like()`](#qiskit.circuit.QuantumCircuit.copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like") in place of [`clear()`](#qiskit.circuit.QuantumCircuit.clear "qiskit.circuit.QuantumCircuit.clear"), and run [`remove_final_measurements()`](#qiskit.circuit.QuantumCircuit.remove_final_measurements "qiskit.circuit.QuantumCircuit.remove_final_measurements") as its transpiler-pass form [`RemoveFinalMeasurements`](qiskit.transpiler.passes.RemoveFinalMeasurements "qiskit.transpiler.passes.RemoveFinalMeasurements"). - **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – All measurements removed inplace or return new circuit. + #### clear - **Returns** + + Clear all instructions in self. - Returns the resulting circuit when `inplace=False`, else None. + Clearing the circuits will keep the metadata and calibrations. - **Return type** + + **[`copy_empty_like()`](#qiskit.circuit.QuantumCircuit.copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like")** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + A method to produce a new circuit with no instructions and all the same tracking of quantum and classical typed data, but without mutating the original circuit. + - ### repeat - - - Repeat this circuit `reps` times. + #### remove\_final\_measurements - **Parameters** + + 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. - **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – How often this circuit should be repeated. + Measurements and barriers are considered final if they are followed by no other operations (aside from other measurements or barriers.) - **Returns** + + This method has rather complex behavior, particularly around the removal of newly idle classical bits and registers. It is much more efficient to avoid adding unnecessary classical data in the first place, rather than trying to remove it later. + - A circuit containing `reps` repetitions of this circuit. + + **[`RemoveFinalMeasurements`](qiskit.transpiler.passes.RemoveFinalMeasurements "qiskit.transpiler.passes.RemoveFinalMeasurements")** - **Return type** + A transpiler pass that removes final measurements and barriers. This does not remove the classical data. If this is your goal, you can call that with: - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - + ```python + from qiskit.circuit import QuantumCircuit + from qiskit.transpiler.passes import RemoveFinalMeasurements - ### reset + qc = QuantumCircuit(2, 2) + qc.h(0) + qc.cx(0, 1) + qc.barrier() + qc.measure([0, 1], [0, 1]) - - Reset the quantum bit(s) to their default state. + pass_ = RemoveFinalMeasurements() + just_bell = pass_(qc) + ``` + **Parameters** - **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – All measurements removed inplace or return new circuit. **Returns** - handle to the added instruction. + Returns the resulting circuit when `inplace=False`, else None. **Return type** - [qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ### reverse\_bits + - - Return a circuit with the opposite order of wires. + ### Manual calibration of instructions - 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. + [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") can store [`calibrations`](#qiskit.circuit.QuantumCircuit.calibrations "qiskit.circuit.QuantumCircuit.calibrations") of instructions that define the pulses used to run them on one particular hardware backend. You can - This method is useful for converting a circuit written in little-endian convention to the big-endian equivalent, and vice versa. + #### add\_calibration - **Returns** + + Register a low-level, custom pulse definition for the given gate. - the circuit with reversed bit order. + **Parameters** - **Return type** + * **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. - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + **Raises** - **Examples** + [**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. + - input: + #### has\_calibration\_for - ```python - ┌───┐ - a_0: ┤ H ├──■───────────────── - └───┘┌─┴─┐ - a_1: ─────┤ X ├──■──────────── - └───┘┌─┴─┐ - a_2: ──────────┤ X ├──■─────── - └───┘┌─┴─┐ - b_0: ───────────────┤ X ├──■── - └───┘┌─┴─┐ - b_1: ────────────────────┤ X ├ - └───┘ - ``` + + 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. + - output: + ## Circuit properties - ```python - ┌───┐ - b_0: ────────────────────┤ X ├ - ┌───┐└─┬─┘ - b_1: ───────────────┤ X ├──■── - ┌───┐└─┬─┘ - a_0: ──────────┤ X ├──■─────── - ┌───┐└─┬─┘ - a_1: ─────┤ X ├──■──────────── - ┌───┐└─┬─┘ - a_2: ┤ H ├──■───────────────── - └───┘ - ``` - + ### Simple circuit metrics - ### reverse\_ops + 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. - - Reverse the circuit by reversing the order of instructions. + Consider the following circuit: - This is done by recursively reversing all instructions. It does not invert (adjoint) any gate. + ```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') + ``` - **Returns** + ![../\_images/qiskit-circuit-QuantumCircuit-4.png](/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-4.png) - the reversed circuit. + 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()`](#qiskit.circuit.QuantumCircuit.width "qiskit.circuit.QuantumCircuit.width") of the circuit: - **Return type** + ```python + assert qc.width() == 12 + ``` - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + We can also just get the number of qubits directly using [`num_qubits`](#qiskit.circuit.QuantumCircuit.num_qubits "qiskit.circuit.QuantumCircuit.num_qubits"): - **Examples** + ```python + assert qc.num_qubits == 12 + ``` - input: + + 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. + - ```python - ┌───┐ - q_0: ┤ H ├─────■────── - └───┘┌────┴─────┐ - q_1: ─────┤ RX(1.57) ├ - └──────────┘ - ``` + It is also straightforward to get the number and type of the gates in a circuit using [`count_ops()`](#qiskit.circuit.QuantumCircuit.count_ops "qiskit.circuit.QuantumCircuit.count_ops"): - output: + ```python + qc.count_ops() + ``` - ```python - ┌───┐ - q_0: ─────■──────┤ H ├ - ┌────┴─────┐└───┘ - q_1: ┤ RX(1.57) ├───── - └──────────┘ - ``` - + ```python + OrderedDict([('cx', 8), ('h', 5), ('x', 3), ('swap', 3)]) + ``` - ### rv + We can also get just the raw count of operations by computing the circuits [`size()`](#qiskit.circuit.QuantumCircuit.size "qiskit.circuit.QuantumCircuit.size"): - - Apply [`RVGate`](qiskit.circuit.library.RVGate "qiskit.circuit.library.RVGate"). + ```python + assert qc.size() == 19 + ``` - For the full matrix form of this gate, see the underlying gate documentation. + A particularly important circuit property is known as the circuit [`depth()`](#qiskit.circuit.QuantumCircuit.depth "qiskit.circuit.QuantumCircuit.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. - Rotation around an arbitrary rotation axis $v$, where $|v|$ is the angle of rotation in radians. + 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: - **Parameters** + ![../\_images/depth.gif](/images/api/qiskit/dev/depth.gif) - * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + We can verify our graphical result using [`QuantumCircuit.depth()`](#qiskit.circuit.QuantumCircuit.depth "qiskit.circuit.QuantumCircuit.depth"): + + ```python + assert qc.depth() == 9 + ``` + + #### count\_ops + + + Count each operation kind in the circuit. **Returns** - A handle to the instructions created. + a breakdown of how many operations of each kind, sorted by amount. **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + OrderedDict - ### rx - - - Apply [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"). + #### depth - For the full matrix form of this gate, see the underlying gate documentation. + + Return circuit depth (i.e., length of critical path). **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. + **filter\_function** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*CircuitInstruction*](qiskit.circuit.CircuitInstruction "qiskit._accelerate.circuit.CircuitInstruction")*],* [*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*]*) – A function to decide which instructions count to increase depth. Should take as a single positional input a [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction"). Instructions for which the function returns `False` are ignored in the computation of the circuit depth. By default filters out “directives”, such as [`Barrier`](circuit#qiskit.circuit.Barrier "qiskit.circuit.Barrier"). **Returns** - A handle to the instructions created. + Depth of circuit. **Return type** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - - - ### rxx - - - Apply [`RXXGate`](qiskit.circuit.library.RXXGate "qiskit.circuit.library.RXXGate"). - - For the full matrix form of this gate, see the underlying gate documentation. - - **Parameters** + [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") - * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + **Examples** - **Returns** + Simple calculation of total circuit depth: - A handle to the instructions created. + ```python + from qiskit.circuit import QuantumCircuit + qc = QuantumCircuit(4) + qc.h(0) + qc.cx(0, 1) + qc.h(2) + qc.cx(2, 3) + assert qc.depth() == 2 + ``` - **Return type** + Modifying the previous example to only calculate the depth of multi-qubit gates: - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + ```python + assert qc.depth(lambda instr: len(instr.qubits) > 1) == 1 + ``` - ### ry - - - Apply [`RYGate`](qiskit.circuit.library.RYGate "qiskit.circuit.library.RYGate"). + #### get\_instructions - For the full matrix form of this gate, see the underlying gate documentation. + + Get instructions matching name. **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. + **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of instruction to. **Returns** - A handle to the instructions created. + list of (instruction, qargs, cargs). **Return type** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + [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)")) - ### ryy - - - Apply [`RYYGate`](qiskit.circuit.library.RYYGate "qiskit.circuit.library.RYYGate"). + #### num\_connected\_components - For the full matrix form of this gate, see the underlying gate documentation. + + How many non-entangled subcircuits can the circuit be factored to. **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + **unitary\_only** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Compute only unitary part of graph. **Returns** - A handle to the instructions created. + Number of connected components in circuit. **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") - ### rz + #### num\_nonlocal\_gates - - Apply [`RZGate`](qiskit.circuit.library.RZGate "qiskit.circuit.library.RZGate"). + + Return number of non-local gates (i.e. involving 2+ qubits). - For the full matrix form of this gate, see the underlying gate documentation. + Conditional nonlocal gates are also included. - **Parameters** + **Return type** - * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + - **Returns** + #### num\_tensor\_factors - A handle to the instructions created. + + 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** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") - ### rzx + #### num\_unitary\_factors - - Apply [`RZXGate`](qiskit.circuit.library.RZXGate "qiskit.circuit.library.RZXGate"). + + Computes the number of tensor factors in the unitary (quantum) part of the circuit only. - For the full matrix form of this gate, see the underlying gate documentation. + **Return type** + + [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + #### size + + + Returns total number of instructions in circuit. **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + **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** - A handle to the instructions created. + Total number of gate operations. **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") - ### rzz - - - Apply [`RZZGate`](qiskit.circuit.library.RZZGate "qiskit.circuit.library.RZZGate"). - - For the full matrix form of this gate, see the underlying gate documentation. - - **Parameters** + #### width - * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + + Return number of qubits plus clbits in circuit. **Returns** - A handle to the instructions created. + Width of circuit. **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") - ### s + ### Accessing scheduling information - - Apply [`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate"). + If a [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") has been scheduled as part of a transpilation pipeline, the timing information for individual qubits can be accessed. The whole-circuit timing information is available through the [`duration`](#qiskit.circuit.QuantumCircuit.duration "qiskit.circuit.QuantumCircuit.duration"), [`unit`](#qiskit.circuit.QuantumCircuit.unit "qiskit.circuit.QuantumCircuit.unit") and [`op_start_times`](#qiskit.circuit.QuantumCircuit.op_start_times "qiskit.circuit.QuantumCircuit.op_start_times") attributes. - For the full matrix form of this gate, see the underlying gate documentation. + #### qubit\_duration + + + 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** - **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + **\*qubits** ([*Qubit*](circuit#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** - A handle to the instructions created. + Return the duration between the first start and last stop time of non-delay instructions **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") - ### sdg + #### qubit\_start\_time - - Apply [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate"). + + Return the start time of the first instruction, excluding delays, over the supplied qubits. Its time unit is `self.unit`. - For the full matrix form of this gate, see the underlying gate documentation. + Return 0 if there are no instructions over qubits **Parameters** - **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + * **\*qubits** ([*Qubit*](circuit#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** - A handle to the instructions created. + 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** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") - ### size + #### qubit\_stop\_time - - Returns total number of instructions in circuit. + + 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** - **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. + * **\*qubits** ([*Qubit*](circuit#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** - Total number of gate operations. + 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** - [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)") - ### store + ## Instruction-like methods - - Store the result of the given real-time classical expression `rvalue` in the memory location defined by `lvalue`. + [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") also contains a small number of methods that are very [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction")-like in detail. You may well find better integration and more API support if you first convert your circuit to an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") ([`to_instruction()`](#qiskit.circuit.QuantumCircuit.to_instruction "qiskit.circuit.QuantumCircuit.to_instruction")) or [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") ([`to_gate()`](#qiskit.circuit.QuantumCircuit.to_gate "qiskit.circuit.QuantumCircuit.to_gate")) as appropriate, then call the corresponding method. - Typically `lvalue` will be a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node and `rvalue` will be some [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") to write into it, but anything that [`expr.lift()`](circuit_classical#qiskit.circuit.classical.expr.lift "qiskit.circuit.classical.expr.lift") can raise to an [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") is permissible in both places, and it will be called on them. + ### control + + + Control this circuit on `num_ctrl_qubits` qubits. **Parameters** - * **lvalue** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – a valid specifier for a memory location in the circuit. This will typically be a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node, but you can also write to [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") or [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") memory locations if your hardware supports it. The memory location must already be present in the circuit. - * **rvalue** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – a real-time classical expression whose result should be written into the given memory location. + * **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`. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. - **Return type** + **Returns** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + The controlled version of this circuit. - - **[`Store`](circuit#qiskit.circuit.Store "qiskit.circuit.Store")** + **Return type** - The backing [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") class that represents this operation. + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - **[`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var")** + **Raises** - Create a new variable in the circuit that can be written to with this method. - + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the circuit contains a non-unitary operation and cannot be controlled. - ### swap + ### inverse - - Apply [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate"). + + Invert (take adjoint of) this circuit. - For the full matrix form of this gate, see the underlying gate documentation. + This is done by recursively inverting all gates. **Parameters** - * **qubit1** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the inverse gate can be implemented as an annotated gate. **Returns** - A handle to the instructions created. + the inverted circuit **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ### switch + **Raises** - - Create a `switch`/`case` structure on this circuit. + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the circuit cannot be inverted. - 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. + **Examples** - Example usage: + input: ```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]) + ┌───┐ + q_0: ┤ H ├─────■────── + └───┘┌────┴─────┐ + q_1: ─────┤ RX(1.57) ├ + └──────────┘ + ``` - 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) + output: + + ```python + ┌───┐ + q_0: ──────■──────┤ H ├ + ┌─────┴─────┐└───┘ + q_1: ┤ RX(-1.57) ├───── + └───────────┘ ``` + + + ### power + + + Raise this circuit to the power of `power`. + + If `power` is a positive integer and both `matrix_power` and `annotated` are `False`, this implementation defaults to calling `repeat`. Otherwise, the circuit is converted into a gate, and a new circuit, containing this gate raised to the given power, is returned. The gate raised to the given power is implemented either as a unitary gate if `annotated` is `False` or as an annotated operation if `annotated` is `True`. **Parameters** - * **target** (*Union\[*[*ClassicalRegister*](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")*,* [*Clbit*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – The circuit qubits over which all case bodies execute. Omit in context-manager form. - * **clbits** (*Sequence\[*[*Clbit*](circuit#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. + * **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)")) – indicates whether the inner power gate can be implemented as a unitary gate. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the inner power gate can be implemented as an annotated operation. - **Returns** + **Raises** - 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. + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the circuit needs to be converted to a unitary gate, but is not unitary. - **Return type** + **Returns** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") or SwitchCaseContext + A circuit implementing this circuit raised to the power of `power`. - **Raises** + **Return type** - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if an incorrect calling convention is used. + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ### sx - - - Apply [`SXGate`](qiskit.circuit.library.SXGate "qiskit.circuit.library.SXGate"). + ### repeat - For the full matrix form of this gate, see the underlying gate documentation. + + Repeat this circuit `reps` times. **Parameters** - **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – How often this circuit should be repeated. **Returns** - A handle to the instructions created. + A circuit containing `reps` repetitions of this circuit. **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ### sxdg - - - Apply [`SXdgGate`](qiskit.circuit.library.SXdgGate "qiskit.circuit.library.SXdgGate"). - - For the full matrix form of this gate, see the underlying gate documentation. + ### reverse\_ops - **Parameters** + + Reverse the circuit by reversing the order of instructions. - **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + This is done by recursively reversing all instructions. It does not invert (adjoint) any gate. **Returns** - A handle to the instructions created. + the reversed circuit. **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [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) ├───── + └──────────┘ + ``` - ### t - - - Apply [`TGate`](qiskit.circuit.library.TGate "qiskit.circuit.library.TGate"). + ## Visualization - For the full matrix form of this gate, see the underlying gate documentation. + Qiskit includes some drawing tools to give you a quick feel for what your circuit looks like. This tooling is primarily targeted at producing either a [Matplotlib](https://matplotlib.org/)- or text-based drawing. There is also a lesser-featured LaTeX backend for drawing, but this is only for simple circuits, and is not as actively maintained. - **Parameters** + + **[`qiskit.visualization`](visualization#module-qiskit.visualization "qiskit.visualization")** - **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + The primary documentation for all of Qiskit’s visualization tooling. + - **Returns** + ### draw - A handle to the instructions created. + + Draw the quantum circuit. Use the output parameter to choose the drawing format: - **Return type** + **text**: ASCII art TextDrawing that can be printed in the console. - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - + **mpl**: images with color rendered purely in Python using matplotlib. - ### tdg + **latex**: high-quality images compiled via latex. - - Apply [`TdgGate`](qiskit.circuit.library.TdgGate "qiskit.circuit.library.TdgGate"). + **latex\_source**: raw uncompiled latex output. - For the full matrix form of this gate, see the underlying gate documentation. + + 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** - **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + * **output** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – 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. - **Return type** + * **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Scale of image to draw (shrink if `< 1.0`). Only used by the `mpl`, `latex` and `latex_source` outputs. Defaults to `1.0`. - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - + * **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – File path to save image to. Defaults to `None` (result not saved in a file). - ### tensor + * **style** ([*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)") *| None*) – - - Tensor `self` with `other`. + Style name, file name of style JSON file, or a dictionary specifying the style. - Remember that in the little-endian convention the leftmost operation will be at the bottom of the circuit. See also [the docs](/build/circuit-construction) for more information. + * The supported style names are `"iqp"` (default), `"iqp-dark"`, `"clifford"`, `"textbook"` and `"bw"`. + * If given a JSON file, e.g. `my_style.json` or `my_style` (the `.json` extension may be omitted), this function attempts to load the style dictionary from that location. Note, that the JSON file must completely specify the visualization specifications. The file is searched for in `qiskit/visualization/circuit/styles`, the current working directory, and the location specified in `~/.qiskit/settings.conf`. + * If a dictionary, every entry overrides the default configuration. If the `"name"` key is given, the default configuration is given by that style. For example, `{"name": "textbook", "subfontsize": 5}` loads the `"texbook"` style and sets the subfontsize (e.g. the gate angles) to `5`. + * If `None` the default style `"iqp"` is used or, if given, the default style specified in `~/.qiskit/settings.conf`. - ```python - ┌────────┐ ┌─────┐ ┌─────┐ - q_0: ┤ bottom ├ ⊗ q_0: ┤ top ├ = q_0: ─┤ top ├── - └────────┘ └─────┘ ┌┴─────┴─┐ - q_1: ┤ bottom ├ - └────────┘ - ``` + * **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`. - **Parameters** + * **reverse\_bits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – 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`. - * **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. + * **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`. - **Return type** + * **justify** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – 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. - [*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") | None + * **vertical\_compression** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – `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. - **Examples** + * **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`. - ```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') - ``` + * **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`. - ![../\_images/qiskit-circuit-QuantumCircuit-6.png](/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-6.png) + * **fold** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – 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. - **Returns** + * **ax** (*Any | None*) – Only used by the mpl backend. An optional `matplotlib.axes.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. - The tensored circuit (returns None if inplace==True). + * **initial\_state** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Adds $|0\rangle$ in the beginning of the qubit wires and $0$ to classical wires. Default is `False`. - **Return type** + * **cregbundle** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If set to `True`, bundle classical registers. Default is `True`, except for when `output` is set to `"text"`. - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - + * **wire\_order** ([*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 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`). - ### to\_gate + * **expr\_len** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – 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. - - Create a Gate out of this circuit. + **Returns** - **Parameters** + `TextDrawing` or `matplotlib.figure` or `PIL.Image` or [`str`](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"): - * **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. + * **`TextDrawing` (if `output='text'`)** - **Returns** + A drawing that can be printed as ascii art. - a composite gate encapsulating this circuit (can be decomposed back) + * **`matplotlib.figure.Figure` (if `output='mpl'`)** - **Return type** + A matplotlib figure object for the circuit diagram. - [Gate](qiskit.circuit.Gate "qiskit.circuit.Gate") - + * **`PIL.Image` (if `output='latex`’)** - ### to\_instruction + An in-memory representation of the image of the circuit diagram. - - Create an Instruction out of this circuit. + * **`str` (if `output='latex_source'`)** - **Parameters** + The LaTeX source code for visualizing the circuit diagram. - * **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. + **Raises** - **Returns** + * [**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. - a composite instruction encapsulating this circuit (can be decomposed back) + **Example** - **Return type** + ```python + from qiskit import QuantumRegister, ClassicalRegister, QuantumCircuit + qc = QuantumCircuit(1, 1) + qc.h(0) + qc.measure(0, 0) + qc.draw(output='mpl', style={'backgroundcolor': '#EEEEEE'}) + ``` - [qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + ![../\_images/qiskit-circuit-QuantumCircuit-5.png](/images/api/qiskit/dev/qiskit-circuit-QuantumCircuit-5.png) - ### u + In addition to the core [`draw()`](#qiskit.circuit.QuantumCircuit.draw "qiskit.circuit.QuantumCircuit.draw") driver, there are two visualization-related helper methods, which are mostly useful for quickly unwrapping some inner instructions or reversing the [qubit-labelling conventions](circuit#circuit-conventions) in the drawing. For more general mutation, including basis-gate rewriting, you should use the transpiler ([`qiskit.transpiler`](transpiler#module-qiskit.transpiler "qiskit.transpiler")). - - Apply [`UGate`](qiskit.circuit.library.UGate "qiskit.circuit.library.UGate"). + ### decompose - For the full matrix form of this gate, see the underlying gate documentation. + + Call a decomposition pass on this circuit, to decompose one level (shallow decompose). **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + * **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 handle to the instructions created. + a circuit one level decomposed **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ### unitary + ### reverse\_bits - - Apply unitary gate specified by `obj` to `qubits`. + + Return a circuit with the opposite order of wires. - **Parameters** + 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. - * **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]. + This method is useful for converting a circuit written in little-endian convention to the big-endian equivalent, and vice versa. **Returns** - The quantum circuit. + the circuit with reversed bit order. **Return type** [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - **Example** + **Examples** - Apply a gate specified by a unitary matrix to a quantum circuit + input: ```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]) + ┌───┐ + a_0: ┤ H ├──■───────────────── + └───┘┌─┴─┐ + a_1: ─────┤ X ├──■──────────── + └───┘┌─┴─┐ + a_2: ──────────┤ X ├──■─────── + └───┘┌─┴─┐ + b_0: ───────────────┤ X ├──■── + └───┘┌─┴─┐ + b_1: ────────────────────┤ X ├ + └───┘ ``` - - - ### while\_loop - - - 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: + output: ```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) + ┌───┐ + b_0: ────────────────────┤ X ├ + ┌───┐└─┬─┘ + b_1: ───────────────┤ X ├──■── + ┌───┐└─┬─┘ + a_0: ──────────┤ X ├──■─────── + ┌───┐└─┬─┘ + a_1: ─────┤ X ├──■──────────── + ┌───┐└─┬─┘ + a_2: ┤ H ├──■───────────────── + └───┘ ``` - - **Parameters** - - * **condition** (*Tuple\[Union\[*[*ClassicalRegister*](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")*,* [*Clbit*](circuit#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`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") or a [`Clbit`](circuit#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*](circuit#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*](circuit#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 + ## Internal utilities - - Return number of qubits plus clbits in circuit. + These functions are not intended for public use, but were accidentally left documented in the public API during the 1.0 release. They will be removed in Qiskit 2.0, but will be supported until then. - **Returns** + ### cast - Width of circuit. + + Best effort to cast value to type. Otherwise, returns the value. **Return type** - [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + *S* | *T* - ### x - - - Apply [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate"). + ### cbit\_argument\_conversion - For the full matrix form of this gate, see the underlying gate documentation. + + Converts several classical bit representations (such as indexes, range, etc.) into a list of classical bits. **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. + **clbit\_representation** (*Object*) – representation to expand **Returns** - A handle to the instructions created. + Where each tuple is a classical bit. **Return type** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + List([tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) - ### y - - - Apply [`YGate`](qiskit.circuit.library.YGate "qiskit.circuit.library.YGate"). + ### cls\_instances - For the full matrix form of this gate, see the underlying gate documentation. + + Return the current number of instances of this class, useful for auto naming. - **Parameters** + **Return type** - **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + - **Returns** + ### cls\_prefix - A handle to the instructions created. + + Return the prefix to use for auto naming. **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") - ### z - - - Apply [`ZGate`](qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate"). + ### qbit\_argument\_conversion - For the full matrix form of this gate, see the underlying gate documentation. + + Converts several qubit representations (such as indexes, range, etc.) into a list of qubits. **Parameters** - **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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. + **qubit\_representation** (*Object*) – representation to expand **Returns** - A handle to the instructions created. + the resolved instances of the qubits. **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + List([Qubit](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")) diff --git a/docs/api/qiskit/dev/qiskit.circuit.SwitchCaseOp.mdx b/docs/api/qiskit/dev/qiskit.circuit.SwitchCaseOp.mdx index 0ca4cc1ee8e..945fa0755aa 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.SwitchCaseOp.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.SwitchCaseOp.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp # SwitchCaseOp - + 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. @@ -123,19 +123,19 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -154,7 +154,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -164,7 +164,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### 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. @@ -176,7 +176,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### 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. @@ -194,7 +194,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### copy - + Copy of the instruction. **Parameters** @@ -212,7 +212,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -236,13 +236,13 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### is\_parameterized - + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### iter\_captured\_vars - + Get an iterator over the unique captured variables in all blocks of this construct. **Return type** @@ -252,7 +252,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### repeat - + Creates an instruction with `self` repeated :math\`n\` times. If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. @@ -276,7 +276,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### replace\_blocks - + Return a new version of this control-flow operations with the [`blocks`](#qiskit.circuit.SwitchCaseOp.blocks "qiskit.circuit.SwitchCaseOp.blocks") mapped to the given new ones. Typically this is used in a workflow such as: @@ -311,7 +311,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### 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. @@ -329,7 +329,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### soft\_compare - + 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** @@ -347,7 +347,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### 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. @@ -355,7 +355,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/dev/qiskit.circuit.WhileLoopOp.mdx b/docs/api/qiskit/dev/qiskit.circuit.WhileLoopOp.mdx index aeabe06c262..2cc88932247 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.WhileLoopOp.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.WhileLoopOp.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.WhileLoopOp # WhileLoopOp - + 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. @@ -124,19 +124,19 @@ python_api_name: qiskit.circuit.WhileLoopOp ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -155,7 +155,7 @@ python_api_name: qiskit.circuit.WhileLoopOp ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -165,7 +165,7 @@ python_api_name: qiskit.circuit.WhileLoopOp ### copy - + Copy of the instruction. **Parameters** @@ -183,7 +183,7 @@ python_api_name: qiskit.circuit.WhileLoopOp ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -207,13 +207,13 @@ python_api_name: qiskit.circuit.WhileLoopOp ### is\_parameterized - + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### iter\_captured\_vars - + Get an iterator over the unique captured variables in all blocks of this construct. **Return type** @@ -223,7 +223,7 @@ python_api_name: qiskit.circuit.WhileLoopOp ### repeat - + Creates an instruction with `self` repeated :math\`n\` times. If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. @@ -247,7 +247,7 @@ python_api_name: qiskit.circuit.WhileLoopOp ### replace\_blocks - + Return a new version of this control-flow operations with the [`blocks`](#qiskit.circuit.WhileLoopOp.blocks "qiskit.circuit.WhileLoopOp.blocks") mapped to the given new ones. Typically this is used in a workflow such as: @@ -278,7 +278,7 @@ python_api_name: qiskit.circuit.WhileLoopOp ### 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. @@ -296,7 +296,7 @@ python_api_name: qiskit.circuit.WhileLoopOp ### soft\_compare - + 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** @@ -314,7 +314,7 @@ python_api_name: qiskit.circuit.WhileLoopOp ### 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. @@ -322,7 +322,7 @@ python_api_name: qiskit.circuit.WhileLoopOp ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.BooleanExpression.mdx b/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.BooleanExpression.mdx index 4a663ecec87..7eec46072e6 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.BooleanExpression.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.BooleanExpression.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression # BooleanExpression - + Bases: `ClassicalElement` The Boolean Expression gate. @@ -120,19 +120,19 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + 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: @@ -185,7 +185,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -195,7 +195,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### control - + Return the controlled version of itself. Implemented either as a controlled gate (ref. [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). @@ -218,7 +218,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### copy - + Copy of the instruction. **Parameters** @@ -236,7 +236,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### from\_dimacs\_file - + Create a BooleanExpression from the string in the DIMACS format. :param filename: A file in DIMACS format. **Returns** @@ -254,7 +254,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -278,13 +278,13 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### is\_parameterized - + Return whether the `Instruction` contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. @@ -305,7 +305,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### repeat - + Creates an instruction with `self` repeated :math\`n\` times. If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. @@ -329,7 +329,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### 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. @@ -347,7 +347,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### simulate - + Evaluate the expression on a bitstring. This evaluation is done classically. @@ -367,7 +367,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### soft\_compare - + 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** @@ -385,7 +385,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### synth - + Synthesis the logic network into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). **Parameters** @@ -404,7 +404,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### to\_matrix - + Return a Numpy.array for the gate unitary matrix. **Returns** @@ -422,7 +422,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### 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. @@ -430,7 +430,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### validate\_parameter - + Gate parameters should be int, float, or ParameterExpression diff --git a/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.ClassicalFunction.mdx b/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.ClassicalFunction.mdx index 3f6ba4fe72e..74dfff9b32b 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.ClassicalFunction.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.ClassicalFunction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction # ClassicalFunction - + Bases: `ClassicalElement` Represent a classical function and its logic network. @@ -171,19 +171,19 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + 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: @@ -236,7 +236,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -246,13 +246,13 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### compile - + Parses and creates the logical circuit ### control - + Return the controlled version of itself. Implemented either as a controlled gate (ref. [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). @@ -275,7 +275,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### copy - + Copy of the instruction. **Parameters** @@ -293,7 +293,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -317,13 +317,13 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### is\_parameterized - + Return whether the `Instruction` contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. @@ -344,7 +344,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### repeat - + Creates an instruction with `self` repeated :math\`n\` times. If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. @@ -368,7 +368,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### 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. @@ -386,7 +386,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### simulate - + Evaluate the expression on a bitstring. This evaluation is done classically. @@ -406,7 +406,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### simulate\_all - + Returns a truth table. **Returns** @@ -420,7 +420,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### soft\_compare - + 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** @@ -438,7 +438,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### synth - + Synthesis the logic network into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). **Parameters** @@ -459,7 +459,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### to\_matrix - + Return a Numpy.array for the gate unitary matrix. **Returns** @@ -477,7 +477,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### 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. @@ -485,7 +485,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### validate\_parameter - + Gate parameters should be int, float, or ParameterExpression diff --git a/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.mdx b/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.mdx index ffde80605fd..320e7c119d7 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeE # qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError - + ClassicalFunction compiler type error. The classicalfunction function fails at type checking time. Set the error message. diff --git a/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.mdx b/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.mdx index 4db718ce921..605ba8b4b05 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunctionParseError # qiskit.circuit.classicalfunction.ClassicalFunctionParseError - + ClassicalFunction compiler parse error. The classicalfunction function fails at parsing time. Set the error message. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.AND.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.AND.mdx index 93de850ff3d..ab5070c83f1 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.AND.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.AND.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.AND # AND - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") A circuit implementing the logical AND operation on a number of qubits. @@ -36,7 +36,7 @@ python_api_name: qiskit.circuit.library.AND ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -50,13 +50,13 @@ python_api_name: qiskit.circuit.library.AND ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -70,12 +70,12 @@ python_api_name: qiskit.circuit.library.AND ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -90,9 +90,9 @@ python_api_name: qiskit.circuit.library.AND ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -232,7 +232,37 @@ python_api_name: qiskit.circuit.library.AND ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.AND.unit "qiskit.circuit.library.AND.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.AND.duration "qiskit.circuit.library.AND.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.C3SXGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.C3SXGate.mdx index 42cd0fc0d4a..ab8bfcd70a4 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.C3SXGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.C3SXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.C3SXGate # C3SXGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") The 3-qubit controlled sqrt-X gate. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.C3XGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.C3XGate.mdx index c601cf906ad..ea7ca2e38bc 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.C3XGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.C3XGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.C3XGate # C3XGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") The X gate controlled on 3 qubits. @@ -154,7 +154,7 @@ python_api_name: qiskit.circuit.library.C3XGate ### control - + Controlled version of this gate. **Parameters** @@ -175,7 +175,7 @@ python_api_name: qiskit.circuit.library.C3XGate ### inverse - + Invert this gate. The C3X is its own inverse. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.C4XGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.C4XGate.mdx index d1058b22160..826c6998aeb 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.C4XGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.C4XGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.C4XGate # C4XGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") The 4-qubit controlled X gate. @@ -158,7 +158,7 @@ python_api_name: qiskit.circuit.library.C4XGate ### control - + Controlled version of this gate. **Parameters** @@ -179,7 +179,7 @@ python_api_name: qiskit.circuit.library.C4XGate ### inverse - + Invert this gate. The C4X is its own inverse. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CCXGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CCXGate.mdx index 55f27ce0f60..bb78c8faef0 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CCXGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CCXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CCXGate # CCXGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") CCX gate, also known as Toffoli gate. @@ -210,7 +210,7 @@ $$ ### control - + Controlled version of this gate. **Parameters** @@ -231,7 +231,7 @@ $$ ### inverse - + Return an inverted CCX gate (also a CCX). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CCZGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CCZGate.mdx index 8824f122105..01d0ab7fb8e 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CCZGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CCZGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CCZGate # CCZGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") CCZ gate. @@ -185,7 +185,7 @@ $$ ### inverse - + Return inverted CCZ gate (itself). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CDKMRippleCarryAdder.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CDKMRippleCarryAdder.mdx index 6bf7b0f4a13..564e798681c 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CDKMRippleCarryAdder.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CDKMRippleCarryAdder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CDKMRippleCarryAdder # CDKMRippleCarryAdder - + Bases: `Adder` A ripple-carry circuit to perform in-place addition on two qubit registers. @@ -82,7 +82,7 @@ python_api_name: qiskit.circuit.library.CDKMRippleCarryAdder ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -96,13 +96,13 @@ python_api_name: qiskit.circuit.library.CDKMRippleCarryAdder ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -116,12 +116,12 @@ python_api_name: qiskit.circuit.library.CDKMRippleCarryAdder ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -136,9 +136,9 @@ python_api_name: qiskit.circuit.library.CDKMRippleCarryAdder ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -288,7 +288,37 @@ python_api_name: qiskit.circuit.library.CDKMRippleCarryAdder ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.CDKMRippleCarryAdder.unit "qiskit.circuit.library.CDKMRippleCarryAdder.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.CDKMRippleCarryAdder.duration "qiskit.circuit.library.CDKMRippleCarryAdder.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CHGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CHGate.mdx index 2cb381c36e9..d5d10ab0655 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CHGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CHGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CHGate # CHGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-Hadamard gate. @@ -200,7 +200,7 @@ $$ ### inverse - + Return inverted CH gate (itself). diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CPhaseGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CPhaseGate.mdx index a8478d4483c..ad00a5fa26f 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CPhaseGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CPhaseGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CPhaseGate # CPhaseGate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Controlled-Phase gate. @@ -181,7 +181,7 @@ $$ ### control - + Controlled version of this gate. **Parameters** @@ -202,13 +202,13 @@ $$ ### inverse - + Return inverted CPhase gate ($CPhase(\lambda)^{\dagger} = CPhase(-\lambda)$) ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CRXGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CRXGate.mdx index 541ba942190..f04d386214e 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CRXGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CRXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CRXGate # CRXGate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Controlled-RX gate. @@ -202,7 +202,7 @@ $$ ### inverse - + Return inverse CRX gate (i.e. with the negative rotation angle). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CRYGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CRYGate.mdx index d4994ee18e1..f5b6daa5b3c 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CRYGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CRYGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CRYGate # CRYGate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Controlled-RY gate. @@ -202,7 +202,7 @@ $$ ### inverse - + Return inverse CRY gate (i.e. with the negative rotation angle) **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CRZGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CRZGate.mdx index 2634260deef..5e0c7fffd08 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CRZGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CRZGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CRZGate # CRZGate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Controlled-RZ gate. @@ -204,7 +204,7 @@ $$ ### inverse - + Return inverse CRZ gate (i.e. with the negative rotation angle). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CSGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CSGate.mdx index 6f2bb0e9cbc..40322fcb00c 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CSGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CSGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CSGate # CSGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-S gate. @@ -176,7 +176,7 @@ $$ ### inverse - + Return inverse of CSGate (CSdgGate). **Parameters** @@ -194,7 +194,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CSXGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CSXGate.mdx index a3cdea12757..3e5c9722e04 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CSXGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CSXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CSXGate # CSXGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-√X gate. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CSdgGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CSdgGate.mdx index c714ffc3313..b694fca208c 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CSdgGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CSdgGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CSdgGate # CSdgGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-S^dagger gate. @@ -176,7 +176,7 @@ $$ ### inverse - + Return inverse of CSdgGate (CSGate). **Parameters** @@ -194,7 +194,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CSwapGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CSwapGate.mdx index 4120dce87ed..ea2e1cd3bc5 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CSwapGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CSwapGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CSwapGate # CSwapGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-SWAP gate, also known as the Fredkin gate. @@ -219,7 +219,7 @@ $$ ### inverse - + Return inverse CSwap gate (itself). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CU1Gate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CU1Gate.mdx index 9f7db79dbb1..cfc684163fc 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CU1Gate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CU1Gate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CU1Gate # CU1Gate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Controlled-U1 gate. @@ -179,7 +179,7 @@ $$ ### control - + Controlled version of this gate. **Parameters** @@ -200,7 +200,7 @@ $$ ### inverse - + Return inverted CU1 gate ($CU1(\lambda)^{\dagger} = CU1(-\lambda))$ **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CU3Gate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CU3Gate.mdx index d4ee7691a6c..092c0a698bf 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CU3Gate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CU3Gate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CU3Gate # CU3Gate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Controlled-U3 gate (3-parameter two-qubit gate). @@ -204,7 +204,7 @@ $$ ### inverse - + Return inverted CU3 gate. $CU3(\theta,\phi,\lambda)^{\dagger} =CU3(-\theta,-\phi,-\lambda))$ diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CUGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CUGate.mdx index 7d33686dd0a..b26d49ac170 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CUGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CUGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CUGate # CUGate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Controlled-U gate (4-parameter two-qubit gate). @@ -194,7 +194,7 @@ $$ ### inverse - + Return inverted CU gate. $CU(\theta,\phi,\lambda,\gamma)^{\dagger} = CU(-\theta,-\phi,-\lambda,-\gamma))$ diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CXGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CXGate.mdx index 236b8a72457..bff9f641d8f 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CXGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CXGate # CXGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-X gate. @@ -206,7 +206,7 @@ $$ ### control - + Return a controlled-X gate with more control lines. **Parameters** @@ -227,7 +227,7 @@ $$ ### inverse - + Return inverted CX gate (itself). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CYGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CYGate.mdx index 287c77d86ca..7aa8ea6f29b 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CYGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CYGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CYGate # CYGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-Y gate. @@ -198,7 +198,7 @@ $$ ### inverse - + Return inverted CY gate (itself). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.CZGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.CZGate.mdx index 6f71854c14b..b77fcb76be2 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.CZGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.CZGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CZGate # CZGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-Z gate. @@ -179,7 +179,7 @@ $$ ### inverse - + Return inverted CZ gate (itself). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.DCXGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.DCXGate.mdx index 09f25a1571a..803f549212d 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.DCXGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.DCXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.DCXGate # DCXGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") Double-CNOT gate. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.Diagonal.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.Diagonal.mdx index 59e89391135..3f43f15365a 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.Diagonal.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.Diagonal.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.Diagonal # Diagonal - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Diagonal circuit. @@ -64,7 +64,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -78,13 +78,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -98,7 +98,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -118,9 +118,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -260,7 +260,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.Diagonal.unit "qiskit.circuit.library.Diagonal.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.Diagonal.duration "qiskit.circuit.library.Diagonal.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.DiagonalGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.DiagonalGate.mdx index 052d786f88c..960b3c99e78 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.DiagonalGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.DiagonalGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.DiagonalGate # DiagonalGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Gate implementing a diagonal transformation. @@ -118,13 +118,13 @@ python_api_name: qiskit.circuit.library.DiagonalGate ### inverse - + Return the inverse of the diagonal gate. ### validate\_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/dev/qiskit.circuit.library.DraperQFTAdder.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.DraperQFTAdder.mdx index 11d716999ed..e5660bf3275 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.DraperQFTAdder.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.DraperQFTAdder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.DraperQFTAdder # DraperQFTAdder - + Bases: `Adder` A circuit that uses QFT to perform in-place addition on two qubit registers. @@ -53,7 +53,7 @@ python_api_name: qiskit.circuit.library.DraperQFTAdder ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -67,13 +67,13 @@ python_api_name: qiskit.circuit.library.DraperQFTAdder ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -87,7 +87,7 @@ python_api_name: qiskit.circuit.library.DraperQFTAdder ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -107,9 +107,9 @@ python_api_name: qiskit.circuit.library.DraperQFTAdder ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -259,7 +259,37 @@ python_api_name: qiskit.circuit.library.DraperQFTAdder ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.DraperQFTAdder.unit "qiskit.circuit.library.DraperQFTAdder.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.DraperQFTAdder.duration "qiskit.circuit.library.DraperQFTAdder.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.ECRGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.ECRGate.mdx index 8e4aeaf600d..bde9872f34d 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.ECRGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.ECRGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.ECRGate # ECRGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") An echoed cross-resonance gate. @@ -164,7 +164,7 @@ $$ ### inverse - + Return inverse ECR gate (itself). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.EfficientSU2.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.EfficientSU2.mdx index feaa35e5104..aefeb3d5e91 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.EfficientSU2.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.EfficientSU2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.EfficientSU2 # EfficientSU2 - + Bases: [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.n_local.two_local.TwoLocal") The hardware efficient SU(2) 2-local circuit. @@ -79,7 +79,7 @@ python_api_name: qiskit.circuit.library.EfficientSU2 ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -93,7 +93,7 @@ python_api_name: qiskit.circuit.library.EfficientSU2 ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -129,7 +129,7 @@ python_api_name: qiskit.circuit.library.EfficientSU2 ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -169,9 +169,9 @@ python_api_name: qiskit.circuit.library.EfficientSU2 ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -331,13 +331,13 @@ python_api_name: qiskit.circuit.library.EfficientSU2 ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -359,5 +359,29 @@ python_api_name: qiskit.circuit.library.EfficientSU2 The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.EfficientSU2.unit "qiskit.circuit.library.EfficientSU2.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.EfficientSU2.duration "qiskit.circuit.library.EfficientSU2.duration") is specified in. + diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.EvolvedOperatorAnsatz.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.EvolvedOperatorAnsatz.mdx index bb565a9c69a..dfcc02d5347 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.EvolvedOperatorAnsatz.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.EvolvedOperatorAnsatz.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz # EvolvedOperatorAnsatz - + Bases: [`NLocal`](qiskit.circuit.library.NLocal "qiskit.circuit.library.n_local.n_local.NLocal") The evolved operator ansatz. @@ -29,7 +29,7 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -43,7 +43,7 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -93,7 +93,7 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -133,9 +133,9 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -305,13 +305,13 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -333,5 +333,29 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.EvolvedOperatorAnsatz.unit "qiskit.circuit.library.EvolvedOperatorAnsatz.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.EvolvedOperatorAnsatz.duration "qiskit.circuit.library.EvolvedOperatorAnsatz.duration") is specified in. + diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.ExactReciprocal.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.ExactReciprocal.mdx index 61a124f5fce..fb6c4a269f6 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.ExactReciprocal.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.ExactReciprocal.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.ExactReciprocal # ExactReciprocal - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Exact reciprocal @@ -33,7 +33,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -47,13 +47,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -67,7 +67,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -87,9 +87,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -229,7 +229,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.ExactReciprocal.unit "qiskit.circuit.library.ExactReciprocal.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.ExactReciprocal.duration "qiskit.circuit.library.ExactReciprocal.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.ExcitationPreserving.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.ExcitationPreserving.mdx index da56cc6f02d..7e8b41d6ee0 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.ExcitationPreserving.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.ExcitationPreserving.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.ExcitationPreserving # ExcitationPreserving - + Bases: [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.n_local.two_local.TwoLocal") The heuristic excitation-preserving wave function ansatz. @@ -98,7 +98,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -112,7 +112,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -148,7 +148,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -188,9 +188,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -350,13 +350,13 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -378,5 +378,29 @@ $$ The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.ExcitationPreserving.unit "qiskit.circuit.library.ExcitationPreserving.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.ExcitationPreserving.duration "qiskit.circuit.library.ExcitationPreserving.duration") is specified in. + diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.FourierChecking.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.FourierChecking.mdx index a72bc246d37..2c92b7df6c9 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.FourierChecking.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.FourierChecking.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.FourierChecking # FourierChecking - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Fourier checking circuit. @@ -47,7 +47,7 @@ python_api_name: qiskit.circuit.library.FourierChecking ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -61,13 +61,13 @@ python_api_name: qiskit.circuit.library.FourierChecking ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -81,7 +81,7 @@ python_api_name: qiskit.circuit.library.FourierChecking ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -101,9 +101,9 @@ python_api_name: qiskit.circuit.library.FourierChecking ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -243,7 +243,37 @@ python_api_name: qiskit.circuit.library.FourierChecking ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.FourierChecking.unit "qiskit.circuit.library.FourierChecking.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.FourierChecking.duration "qiskit.circuit.library.FourierChecking.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.FunctionalPauliRotations.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.FunctionalPauliRotations.mdx index d3e944489b3..0331b438301 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.FunctionalPauliRotations.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.FunctionalPauliRotations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.FunctionalPauliRotations # FunctionalPauliRotations - + Bases: `BlueprintCircuit`, [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Base class for functional Pauli rotations. @@ -26,7 +26,7 @@ python_api_name: qiskit.circuit.library.FunctionalPauliRotations ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### basis @@ -52,7 +52,7 @@ python_api_name: qiskit.circuit.library.FunctionalPauliRotations ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -62,7 +62,7 @@ python_api_name: qiskit.circuit.library.FunctionalPauliRotations ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -82,9 +82,9 @@ python_api_name: qiskit.circuit.library.FunctionalPauliRotations ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancilla\_qubits @@ -188,13 +188,37 @@ python_api_name: qiskit.circuit.library.FunctionalPauliRotations ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.FunctionalPauliRotations.unit "qiskit.circuit.library.FunctionalPauliRotations.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.FunctionalPauliRotations.duration "qiskit.circuit.library.FunctionalPauliRotations.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.GMS.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.GMS.mdx index d92d8d329c0..e2dc09e69e6 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.GMS.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.GMS.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GMS # GMS - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Global Mølmer–Sørensen gate. @@ -56,7 +56,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -70,13 +70,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -90,7 +90,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -110,9 +110,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -252,7 +252,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.GMS.unit "qiskit.circuit.library.GMS.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.GMS.duration "qiskit.circuit.library.GMS.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.GR.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.GR.mdx index f39e9ff6766..4ffac205c03 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.GR.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.GR.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GR # GR - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Global R gate. @@ -50,7 +50,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -64,13 +64,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -84,7 +84,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -104,9 +104,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -246,7 +246,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.GR.unit "qiskit.circuit.library.GR.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.GR.duration "qiskit.circuit.library.GR.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.GRX.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.GRX.mdx index 8f811dedffe..8ec1001be0f 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.GRX.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.GRX.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GRX # GRX - + Bases: [`GR`](qiskit.circuit.library.GR "qiskit.circuit.library.generalized_gates.gr.GR") Global RX gate. @@ -49,7 +49,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -63,13 +63,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -83,7 +83,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -103,9 +103,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -245,7 +245,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.GRX.unit "qiskit.circuit.library.GRX.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.GRX.duration "qiskit.circuit.library.GRX.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.GRY.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.GRY.mdx index 079f4d2229a..f13460b6e21 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.GRY.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.GRY.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GRY # GRY - + Bases: [`GR`](qiskit.circuit.library.GR "qiskit.circuit.library.generalized_gates.gr.GR") Global RY gate. @@ -49,7 +49,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -63,13 +63,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -83,7 +83,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -103,9 +103,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -245,7 +245,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.GRY.unit "qiskit.circuit.library.GRY.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.GRY.duration "qiskit.circuit.library.GRY.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.GRZ.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.GRZ.mdx index e74821baffe..d882a97b1c9 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.GRZ.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.GRZ.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GRZ # GRZ - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Global RZ gate. @@ -49,7 +49,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -63,13 +63,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -83,7 +83,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -103,9 +103,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -245,7 +245,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.GRZ.unit "qiskit.circuit.library.GRZ.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.GRZ.duration "qiskit.circuit.library.GRZ.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.GlobalPhaseGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.GlobalPhaseGate.mdx index 4b9558d26b6..fb5bb56273b 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.GlobalPhaseGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.GlobalPhaseGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GlobalPhaseGate # GlobalPhaseGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") The global phase gate ($e^{i\theta}$). @@ -132,7 +132,7 @@ $$ ### inverse - + Return inverse GlobalPhaseGate gate. $\text{GlobalPhaseGate}(\lambda)^{\dagger} = \text{GlobalPhaseGate}(-\lambda)$ diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.GraphState.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.GraphState.mdx index c7ee7f8c756..b516164828b 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.GraphState.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.GraphState.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GraphState # GraphState - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Circuit to prepare a graph state. @@ -54,7 +54,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -68,13 +68,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -88,7 +88,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -108,9 +108,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -250,7 +250,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.GraphState.unit "qiskit.circuit.library.GraphState.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.GraphState.duration "qiskit.circuit.library.GraphState.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.GroverOperator.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.GroverOperator.mdx index e95caed32db..1b877bcce67 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.GroverOperator.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.GroverOperator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GroverOperator # GroverOperator - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") The Grover operator. @@ -165,7 +165,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -179,13 +179,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -199,7 +199,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -219,9 +219,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -367,7 +367,7 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reflection\_qubits @@ -387,5 +387,35 @@ $$ The subcircuit implementing the reflection about 0. + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.GroverOperator.unit "qiskit.circuit.library.GroverOperator.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.GroverOperator.duration "qiskit.circuit.library.GroverOperator.duration") is specified in. + diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.HGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.HGate.mdx index 0a09fe6e5e4..532c8d41740 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.HGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.HGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.HGate # HGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") Single-qubit Hadamard gate. @@ -138,7 +138,7 @@ $$ ### control - + Return a (multi-)controlled-H gate. One control qubit returns a CH gate. @@ -161,7 +161,7 @@ $$ ### inverse - + Return inverted H gate (itself). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.HRSCumulativeMultiplier.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.HRSCumulativeMultiplier.mdx index 2dbd61f84dd..1e13be2d65b 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.HRSCumulativeMultiplier.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.HRSCumulativeMultiplier.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.HRSCumulativeMultiplier # HRSCumulativeMultiplier - + Bases: `Multiplier` A multiplication circuit to store product of two input registers out-of-place. @@ -66,7 +66,7 @@ python_api_name: qiskit.circuit.library.HRSCumulativeMultiplier ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -80,13 +80,13 @@ python_api_name: qiskit.circuit.library.HRSCumulativeMultiplier ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -100,7 +100,7 @@ python_api_name: qiskit.circuit.library.HRSCumulativeMultiplier ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -120,9 +120,9 @@ python_api_name: qiskit.circuit.library.HRSCumulativeMultiplier ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -282,7 +282,37 @@ python_api_name: qiskit.circuit.library.HRSCumulativeMultiplier ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.HRSCumulativeMultiplier.unit "qiskit.circuit.library.HRSCumulativeMultiplier.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.HRSCumulativeMultiplier.duration "qiskit.circuit.library.HRSCumulativeMultiplier.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.HamiltonianGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.HamiltonianGate.mdx index 5918611a2e9..4116ca72e63 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.HamiltonianGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.HamiltonianGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.HamiltonianGate # HamiltonianGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Class for representing evolution by a Hamiltonian operator as a gate. @@ -126,31 +126,31 @@ python_api_name: qiskit.circuit.library.HamiltonianGate ### adjoint - + Return the adjoint of the unitary. ### conjugate - + Return the conjugate of the Hamiltonian. ### inverse - + Return the adjoint of the unitary. ### transpose - + Return the transpose of the Hamiltonian. ### validate\_parameter - + Hamiltonian parameter has to be an ndarray, operator or float. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.HiddenLinearFunction.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.HiddenLinearFunction.mdx index 5cbe9fe6128..bf33e598006 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.HiddenLinearFunction.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.HiddenLinearFunction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.HiddenLinearFunction # HiddenLinearFunction - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Circuit to solve the hidden linear function problem. @@ -56,7 +56,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -70,13 +70,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -90,7 +90,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -110,9 +110,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -252,7 +252,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.HiddenLinearFunction.unit "qiskit.circuit.library.HiddenLinearFunction.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.HiddenLinearFunction.duration "qiskit.circuit.library.HiddenLinearFunction.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.IGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.IGate.mdx index 1a9124ac5f3..a63cce294bb 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.IGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.IGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.IGate # IGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") Identity gate. @@ -137,7 +137,7 @@ $$ ### inverse - + Returne the inverse gate (itself). **Parameters** @@ -157,7 +157,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.IQP.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.IQP.mdx index 6475bf8f7af..8a592cd8e4a 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.IQP.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.IQP.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.IQP # IQP - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Instantaneous quantum polynomial (IQP) circuit. @@ -44,7 +44,7 @@ python_api_name: qiskit.circuit.library.IQP ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -58,13 +58,13 @@ python_api_name: qiskit.circuit.library.IQP ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -78,7 +78,7 @@ python_api_name: qiskit.circuit.library.IQP ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -98,9 +98,9 @@ python_api_name: qiskit.circuit.library.IQP ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -240,7 +240,37 @@ python_api_name: qiskit.circuit.library.IQP ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.IQP.unit "qiskit.circuit.library.IQP.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.IQP.duration "qiskit.circuit.library.IQP.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.Initialize.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.Initialize.mdx index d65856b48b4..d5ffb9896c5 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.Initialize.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.Initialize.mdx @@ -8,13 +8,19 @@ python_api_name: qiskit.circuit.library.Initialize # Initialize - + 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. + The initial state is prepared based on the [`Isometry`](qiskit.circuit.library.Isometry "qiskit.circuit.library.Isometry") synthesis described in \[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** * **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)")) – @@ -130,7 +136,7 @@ python_api_name: qiskit.circuit.library.Initialize ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -149,7 +155,7 @@ python_api_name: qiskit.circuit.library.Initialize ### gates\_to\_uncompute - + Call to create a circuit with gates that take the desired vector to zero. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.InnerProduct.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.InnerProduct.mdx index e6d42dee0d5..87800095ac8 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.InnerProduct.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.InnerProduct.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.InnerProduct # InnerProduct - + 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$. @@ -55,7 +55,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -69,13 +69,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -89,7 +89,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -109,9 +109,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -251,7 +251,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.InnerProduct.unit "qiskit.circuit.library.InnerProduct.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.InnerProduct.duration "qiskit.circuit.library.InnerProduct.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.IntegerComparator.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.IntegerComparator.mdx index 91e192e4b18..7739f88072e 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.IntegerComparator.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.IntegerComparator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.IntegerComparator # IntegerComparator - + Bases: `BlueprintCircuit` Integer Comparator. @@ -35,7 +35,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -49,7 +49,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -69,7 +69,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -89,9 +89,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -185,13 +185,13 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### value @@ -203,5 +203,29 @@ $$ The value against which the value of the qubit register is compared. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.IntegerComparator.unit "qiskit.circuit.library.IntegerComparator.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.IntegerComparator.duration "qiskit.circuit.library.IntegerComparator.duration") is specified in. + diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.Isometry.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.Isometry.mdx index ef8c437939a..0e982ccec21 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.Isometry.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.Isometry.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.Isometry # Isometry - + Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") Decomposition of arbitrary isometries from $m$ to $n$ qubits. @@ -17,11 +17,9 @@ python_api_name: qiskit.circuit.library.Isometry The decomposition is based on \[1]. - **References:** + **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). + 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** @@ -131,13 +129,13 @@ python_api_name: qiskit.circuit.library.Isometry ### inv\_gate - + Return the adjoint of the unitary. ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -161,7 +159,7 @@ python_api_name: qiskit.circuit.library.Isometry ### validate\_parameter - + Isometry parameter has to be an ndarray. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.LinearAmplitudeFunction.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.LinearAmplitudeFunction.mdx index f548dd391ea..76804108950 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.LinearAmplitudeFunction.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.LinearAmplitudeFunction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.LinearAmplitudeFunction # LinearAmplitudeFunction - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") A circuit implementing a (piecewise) linear function on qubit amplitudes. @@ -70,7 +70,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -84,13 +84,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -104,7 +104,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -124,9 +124,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -266,14 +266,44 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.LinearAmplitudeFunction.unit "qiskit.circuit.library.LinearAmplitudeFunction.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.LinearAmplitudeFunction.duration "qiskit.circuit.library.LinearAmplitudeFunction.duration") is specified in. ## Methods ### post\_processing - + Map the function value of the approximated $\hat{f}$ to $f$. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.LinearFunction.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.LinearFunction.mdx index 73e23a4d968..3d1badfbb71 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.LinearFunction.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.LinearFunction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.LinearFunction # LinearFunction - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") A linear reversible circuit on n qubits. @@ -167,7 +167,7 @@ $$ ### extend\_with\_identity - + Extend linear function to a linear function over nq qubits, with identities on other subsystems. **Parameters** @@ -186,13 +186,13 @@ $$ ### function\_str - + Return string representation of the linear function viewed as a linear transformation. ### 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** @@ -202,19 +202,19 @@ $$ ### mat\_str - + Return string representation of the linear function viewed as a matrix with 0/1 entries. ### 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 - + Synthesizes the linear function into a quantum circuit. **Returns** @@ -228,7 +228,7 @@ $$ ### validate\_parameter - + Parameter validation diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.LinearPauliRotations.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.LinearPauliRotations.mdx index 170bda93d79..7464e91c8a7 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.LinearPauliRotations.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.LinearPauliRotations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.LinearPauliRotations # LinearPauliRotations - + Bases: [`FunctionalPauliRotations`](qiskit.circuit.library.FunctionalPauliRotations "qiskit.circuit.library.arithmetic.functional_pauli_rotations.FunctionalPauliRotations") Linearly-controlled X, Y or Z rotation. @@ -49,7 +49,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### basis @@ -75,7 +75,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -85,7 +85,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -105,9 +105,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancilla\_qubits @@ -223,13 +223,13 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### slope @@ -243,5 +243,29 @@ $$ The rotation angle common in all controlled rotations. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.LinearPauliRotations.unit "qiskit.circuit.library.LinearPauliRotations.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.LinearPauliRotations.duration "qiskit.circuit.library.LinearPauliRotations.duration") is specified in. + diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.MCMT.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.MCMT.mdx index ce12fd35e85..81479d5176a 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.MCMT.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.MCMT.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MCMT # MCMT - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") The multi-controlled multi-target gate, for an arbitrary singly controlled target gate. @@ -48,7 +48,7 @@ python_api_name: qiskit.circuit.library.MCMT ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -62,13 +62,13 @@ python_api_name: qiskit.circuit.library.MCMT ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -82,7 +82,7 @@ python_api_name: qiskit.circuit.library.MCMT ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -102,9 +102,9 @@ python_api_name: qiskit.circuit.library.MCMT ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancilla\_qubits @@ -250,20 +250,50 @@ python_api_name: qiskit.circuit.library.MCMT ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.MCMT.unit "qiskit.circuit.library.MCMT.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.MCMT.duration "qiskit.circuit.library.MCMT.duration") is specified in. ## Methods ### control - + Return the controlled version of the MCMT circuit. ### inverse - + Return the inverse MCMT circuit, which is itself. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.MCMTVChain.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.MCMTVChain.mdx index 99737a00ebd..f90a2274e32 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.MCMTVChain.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.MCMTVChain.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MCMTVChain # MCMTVChain - + Bases: [`MCMT`](qiskit.circuit.library.MCMT "qiskit.circuit.library.generalized_gates.mcmt.MCMT") The MCMT implementation using the CCX V-chain. @@ -72,7 +72,7 @@ python_api_name: qiskit.circuit.library.MCMTVChain ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -86,13 +86,13 @@ python_api_name: qiskit.circuit.library.MCMTVChain ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -106,7 +106,7 @@ python_api_name: qiskit.circuit.library.MCMTVChain ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -126,9 +126,9 @@ python_api_name: qiskit.circuit.library.MCMTVChain ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancilla\_qubits @@ -274,14 +274,44 @@ python_api_name: qiskit.circuit.library.MCMTVChain ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.MCMTVChain.unit "qiskit.circuit.library.MCMTVChain.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.MCMTVChain.duration "qiskit.circuit.library.MCMTVChain.duration") is specified in. ## Methods ### inverse - + Return the inverse MCMT circuit, which is itself. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.MCPhaseGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.MCPhaseGate.mdx index bccefed3e87..7a7ecf3a790 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.MCPhaseGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.MCPhaseGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MCPhaseGate # MCPhaseGate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Multi-controlled-Phase gate. @@ -173,7 +173,7 @@ python_api_name: qiskit.circuit.library.MCPhaseGate ### control - + Controlled version of this gate. **Parameters** @@ -194,7 +194,7 @@ python_api_name: qiskit.circuit.library.MCPhaseGate ### inverse - + Return inverted MCPhase gate ($MCPhase(\lambda)^{\dagger} = MCPhase(-\lambda)$) diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.MCXGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.MCXGate.mdx index 7cb401f7c52..e3f5b64a912 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.MCXGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.MCXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MCXGate # MCXGate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") The general, multi-controlled X gate. @@ -160,7 +160,7 @@ python_api_name: qiskit.circuit.library.MCXGate ### control - + Return a multi-controlled-X gate with more control lines. **Parameters** @@ -181,7 +181,7 @@ python_api_name: qiskit.circuit.library.MCXGate ### get\_num\_ancilla\_qubits - + 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. @@ -193,7 +193,7 @@ python_api_name: qiskit.circuit.library.MCXGate ### inverse - + Invert this gate. The MCX is its own inverse. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.MCXGrayCode.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.MCXGrayCode.mdx index 8ce27c1fcdc..fe9642421c1 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.MCXGrayCode.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.MCXGrayCode.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MCXGrayCode # MCXGrayCode - + Bases: [`MCXGate`](qiskit.circuit.library.MCXGate "qiskit.circuit.library.standard_gates.x.MCXGate") Implement the multi-controlled X gate using the Gray code. @@ -160,7 +160,7 @@ python_api_name: qiskit.circuit.library.MCXGrayCode ### inverse - + Invert this gate. The MCX is its own inverse. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.MCXRecursive.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.MCXRecursive.mdx index ce98e43d8d4..1a548205395 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.MCXRecursive.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.MCXRecursive.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MCXRecursive # MCXRecursive - + Bases: [`MCXGate`](qiskit.circuit.library.MCXGate "qiskit.circuit.library.standard_gates.x.MCXGate") Implement the multi-controlled X gate using recursion. @@ -160,13 +160,13 @@ python_api_name: qiskit.circuit.library.MCXRecursive ### get\_num\_ancilla\_qubits - + Get the number of required ancilla qubits. ### inverse - + Invert this gate. The MCX is its own inverse. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.MCXVChain.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.MCXVChain.mdx index 2fe4ae1b65c..241b9a5cfe0 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.MCXVChain.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.MCXVChain.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MCXVChain # MCXVChain - + 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. @@ -158,13 +158,13 @@ python_api_name: qiskit.circuit.library.MCXVChain ### get\_num\_ancilla\_qubits - + Get the number of required ancilla qubits. ### inverse - + Invert this gate. The MCX is its own inverse. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.MSGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.MSGate.mdx index c635fc01e48..1f1176f34e5 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.MSGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.MSGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MSGate # MSGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") MSGate has been deprecated. Please use `GMS` in `qiskit.circuit.generalized_gates` instead. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.NLocal.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.NLocal.mdx index 8fd22018760..ccd15ac2426 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.NLocal.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.NLocal.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.NLocal # NLocal - + Bases: `BlueprintCircuit` The n-local circuit class. @@ -65,7 +65,7 @@ python_api_name: qiskit.circuit.library.NLocal ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -79,7 +79,7 @@ python_api_name: qiskit.circuit.library.NLocal ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -115,7 +115,7 @@ python_api_name: qiskit.circuit.library.NLocal ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -155,9 +155,9 @@ python_api_name: qiskit.circuit.library.NLocal ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -317,13 +317,13 @@ python_api_name: qiskit.circuit.library.NLocal ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -346,11 +346,35 @@ python_api_name: qiskit.circuit.library.NLocal The blocks in the rotation layers. + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.NLocal.unit "qiskit.circuit.library.NLocal.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.NLocal.duration "qiskit.circuit.library.NLocal.duration") is specified in. + + ## Methods ### add\_layer - + Append another layer to the NLocal. **Parameters** @@ -374,7 +398,7 @@ python_api_name: qiskit.circuit.library.NLocal ### assign\_parameters - + 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"). @@ -394,7 +418,7 @@ python_api_name: qiskit.circuit.library.NLocal ### get\_entangler\_map - + 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. @@ -435,7 +459,7 @@ python_api_name: qiskit.circuit.library.NLocal ### get\_unentangled\_qubits - + Get the indices of unentangled qubits in a set. **Returns** @@ -449,7 +473,7 @@ python_api_name: qiskit.circuit.library.NLocal ### print\_settings - + Returns information about the setting. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.OR.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.OR.mdx index a6d0d76d271..eb522c1cef6 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.OR.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.OR.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.OR # OR - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") A circuit implementing the logical OR operation on a number of qubits. @@ -36,7 +36,7 @@ python_api_name: qiskit.circuit.library.OR ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -50,13 +50,13 @@ python_api_name: qiskit.circuit.library.OR ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -70,7 +70,7 @@ python_api_name: qiskit.circuit.library.OR ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -90,9 +90,9 @@ python_api_name: qiskit.circuit.library.OR ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -232,7 +232,37 @@ python_api_name: qiskit.circuit.library.OR ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.OR.unit "qiskit.circuit.library.OR.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.OR.duration "qiskit.circuit.library.OR.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.PauliEvolutionGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.PauliEvolutionGate.mdx index 4c4256d40ae..ada8c85daa9 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.PauliEvolutionGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.PauliEvolutionGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PauliEvolutionGate # PauliEvolutionGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Time-evolution of an operator consisting of Paulis. @@ -179,7 +179,7 @@ $$ ### validate\_parameter - + Gate parameters should be int, float, or ParameterExpression **Return type** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.PauliFeatureMap.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.PauliFeatureMap.mdx index 2fbb81402be..3fe914f9f0f 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.PauliFeatureMap.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.PauliFeatureMap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PauliFeatureMap # PauliFeatureMap - + Bases: [`NLocal`](qiskit.circuit.library.NLocal "qiskit.circuit.library.n_local.n_local.NLocal") The Pauli Expansion circuit. @@ -124,7 +124,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -138,7 +138,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -178,7 +178,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -218,9 +218,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -380,13 +380,13 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -409,17 +409,41 @@ $$ The blocks in the rotation layers. + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PauliFeatureMap.unit "qiskit.circuit.library.PauliFeatureMap.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PauliFeatureMap.duration "qiskit.circuit.library.PauliFeatureMap.duration") is specified in. + + ## Methods ### pauli\_block - + Get the Pauli block for the feature map circuit. ### pauli\_evolution - + Get the evolution block for the given pauli string. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.PauliGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.PauliGate.mdx index b9511cdc35e..7ec13d92372 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.PauliGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.PauliGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PauliGate # PauliGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") A multi-qubit Pauli gate. @@ -129,13 +129,13 @@ python_api_name: qiskit.circuit.library.PauliGate ### inverse - + Return inverted pauli gate (itself). ### validate\_parameter - + Gate parameters should be int, float, or ParameterExpression diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.PauliTwoDesign.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.PauliTwoDesign.mdx index f50246cdec6..d13fd99372b 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.PauliTwoDesign.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.PauliTwoDesign.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign # PauliTwoDesign - + Bases: [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.n_local.two_local.TwoLocal") The Pauli Two-Design ansatz. @@ -63,7 +63,7 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -77,7 +77,7 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -113,7 +113,7 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -153,9 +153,9 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -309,13 +309,13 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -337,5 +337,29 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PauliTwoDesign.unit "qiskit.circuit.library.PauliTwoDesign.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PauliTwoDesign.duration "qiskit.circuit.library.PauliTwoDesign.duration") is specified in. + diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.Permutation.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.Permutation.mdx index ecb9a5c3fd7..543846e154a 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.Permutation.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.Permutation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.Permutation # Permutation - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") An n\_qubit circuit that permutes qubits. @@ -38,7 +38,7 @@ python_api_name: qiskit.circuit.library.Permutation ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -52,13 +52,13 @@ python_api_name: qiskit.circuit.library.Permutation ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -72,7 +72,7 @@ python_api_name: qiskit.circuit.library.Permutation ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -92,9 +92,9 @@ python_api_name: qiskit.circuit.library.Permutation ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -234,7 +234,37 @@ python_api_name: qiskit.circuit.library.Permutation ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.Permutation.unit "qiskit.circuit.library.Permutation.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.Permutation.duration "qiskit.circuit.library.Permutation.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.PermutationGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.PermutationGate.mdx index 19abcb65d02..197a9b73c42 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.PermutationGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.PermutationGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PermutationGate # PermutationGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") A gate that permutes qubits. @@ -138,13 +138,13 @@ python_api_name: qiskit.circuit.library.PermutationGate ### inverse - + Returns the inverse of the permutation. ### validate\_parameter - + Parameter validation. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.PhaseEstimation.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.PhaseEstimation.mdx index 06a95b1222e..fb631787e58 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.PhaseEstimation.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.PhaseEstimation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PhaseEstimation # PhaseEstimation - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Phase Estimation circuit. @@ -55,7 +55,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -69,13 +69,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -89,7 +89,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -109,9 +109,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -251,7 +251,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PhaseEstimation.unit "qiskit.circuit.library.PhaseEstimation.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PhaseEstimation.duration "qiskit.circuit.library.PhaseEstimation.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.PhaseGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.PhaseGate.mdx index 20ee162047f..b04b3df73b8 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.PhaseGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.PhaseGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PhaseGate # PhaseGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Single-qubit rotation about the Z axis. @@ -162,7 +162,7 @@ $$ ### control - + Return a (multi-)controlled-Phase gate. **Parameters** @@ -183,7 +183,7 @@ $$ ### inverse - + Return inverted Phase gate ($Phase(\lambda)^{\dagger} = Phase(-\lambda)$) **Parameters** @@ -201,7 +201,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.PhaseOracle.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.PhaseOracle.mdx index 29e746e1e58..c024469cda7 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.PhaseOracle.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.PhaseOracle.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PhaseOracle # PhaseOracle - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Phase Oracle. @@ -32,7 +32,7 @@ python_api_name: qiskit.circuit.library.PhaseOracle ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -46,13 +46,13 @@ python_api_name: qiskit.circuit.library.PhaseOracle ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -66,7 +66,7 @@ python_api_name: qiskit.circuit.library.PhaseOracle ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -86,9 +86,9 @@ python_api_name: qiskit.circuit.library.PhaseOracle ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -228,14 +228,44 @@ python_api_name: qiskit.circuit.library.PhaseOracle ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PhaseOracle.unit "qiskit.circuit.library.PhaseOracle.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PhaseOracle.duration "qiskit.circuit.library.PhaseOracle.duration") is specified in. ## Methods ### evaluate\_bitstring - + Evaluate the oracle on a bitstring. This evaluation is done classically without any quantum circuit. **Parameters** @@ -253,7 +283,7 @@ python_api_name: qiskit.circuit.library.PhaseOracle ### from\_dimacs\_file - + 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. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.PiecewiseChebyshev.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.PiecewiseChebyshev.mdx index 3972abb335e..bcdf2552a2b 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.PiecewiseChebyshev.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.PiecewiseChebyshev.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PiecewiseChebyshev # PiecewiseChebyshev - + Bases: `BlueprintCircuit` Piecewise Chebyshev approximation to an input function. @@ -57,7 +57,7 @@ python_api_name: qiskit.circuit.library.PiecewiseChebyshev ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### breakpoints @@ -81,7 +81,7 @@ python_api_name: qiskit.circuit.library.PiecewiseChebyshev ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -111,7 +111,7 @@ python_api_name: qiskit.circuit.library.PiecewiseChebyshev ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -131,9 +131,9 @@ python_api_name: qiskit.circuit.library.PiecewiseChebyshev ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -241,13 +241,37 @@ python_api_name: qiskit.circuit.library.PiecewiseChebyshev ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PiecewiseChebyshev.unit "qiskit.circuit.library.PiecewiseChebyshev.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PiecewiseChebyshev.duration "qiskit.circuit.library.PiecewiseChebyshev.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.PiecewiseLinearPauliRotations.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.PiecewiseLinearPauliRotations.mdx index 51ccdf16f58..f2e81fbe202 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.PiecewiseLinearPauliRotations.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.PiecewiseLinearPauliRotations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PiecewiseLinearPauliRotations # PiecewiseLinearPauliRotations - + Bases: [`FunctionalPauliRotations`](qiskit.circuit.library.FunctionalPauliRotations "qiskit.circuit.library.arithmetic.functional_pauli_rotations.FunctionalPauliRotations") Piecewise-linearly-controlled Pauli rotations. @@ -40,7 +40,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### basis @@ -74,7 +74,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### contains\_zero\_breakpoint @@ -94,7 +94,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -134,9 +134,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancilla\_qubits @@ -248,13 +248,13 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### slopes @@ -265,11 +265,35 @@ $$ The function is linear in the intervals `[point_i, point_{i+1}]` where the last point implicitly is `2**(num_state_qubits + 1)`. + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PiecewiseLinearPauliRotations.unit "qiskit.circuit.library.PiecewiseLinearPauliRotations.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PiecewiseLinearPauliRotations.duration "qiskit.circuit.library.PiecewiseLinearPauliRotations.duration") is specified in. + + ## Methods ### evaluate - + Classically evaluate the piecewise linear rotation. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.PiecewisePolynomialPauliRotations.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.PiecewisePolynomialPauliRotations.mdx index 4fc0283d32f..6061c886851 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.PiecewisePolynomialPauliRotations.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.PiecewisePolynomialPauliRotations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PiecewisePolynomialPauliRotations # PiecewisePolynomialPauliRotations - + Bases: [`FunctionalPauliRotations`](qiskit.circuit.library.FunctionalPauliRotations "qiskit.circuit.library.arithmetic.functional_pauli_rotations.FunctionalPauliRotations") Piecewise-polynomially-controlled Pauli rotations. @@ -84,7 +84,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### basis @@ -122,7 +122,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### coeffs @@ -152,7 +152,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -182,9 +182,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancilla\_qubits @@ -288,20 +288,44 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PiecewisePolynomialPauliRotations.unit "qiskit.circuit.library.PiecewisePolynomialPauliRotations.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PiecewisePolynomialPauliRotations.duration "qiskit.circuit.library.PiecewisePolynomialPauliRotations.duration") is specified in. ## Methods ### evaluate - + Classically evaluate the piecewise polynomial rotation. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.PolynomialPauliRotations.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.PolynomialPauliRotations.mdx index 9f09e454b8b..c5c0d7f62f5 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.PolynomialPauliRotations.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.PolynomialPauliRotations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PolynomialPauliRotations # PolynomialPauliRotations - + Bases: [`FunctionalPauliRotations`](qiskit.circuit.library.FunctionalPauliRotations "qiskit.circuit.library.arithmetic.functional_pauli_rotations.FunctionalPauliRotations") A circuit implementing polynomial Pauli rotations. @@ -48,7 +48,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### basis @@ -74,7 +74,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### coeffs @@ -112,7 +112,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -132,9 +132,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancilla\_qubits @@ -238,13 +238,37 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PolynomialPauliRotations.unit "qiskit.circuit.library.PolynomialPauliRotations.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PolynomialPauliRotations.duration "qiskit.circuit.library.PolynomialPauliRotations.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.QAOAAnsatz.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.QAOAAnsatz.mdx index 77f87e29017..b5c0b19f321 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.QAOAAnsatz.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.QAOAAnsatz.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz # QAOAAnsatz - + Bases: [`EvolvedOperatorAnsatz`](qiskit.circuit.library.EvolvedOperatorAnsatz "qiskit.circuit.library.n_local.evolved_operator_ansatz.EvolvedOperatorAnsatz") A generalized QAOA quantum circuit with a support of custom initial states and mixers. @@ -33,7 +33,7 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -47,7 +47,7 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### cost\_operator @@ -111,7 +111,7 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -147,9 +147,9 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### mixer\_operator @@ -329,13 +329,13 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -353,5 +353,29 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.QAOAAnsatz.unit "qiskit.circuit.library.QAOAAnsatz.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.QAOAAnsatz.duration "qiskit.circuit.library.QAOAAnsatz.duration") is specified in. + diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.QFT.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.QFT.mdx index ac59fea9b25..2c126e87e74 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.QFT.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.QFT.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.QFT # QFT - + Bases: `BlueprintCircuit` Quantum Fourier Transform Circuit. @@ -51,7 +51,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### approximation\_degree @@ -75,7 +75,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -95,7 +95,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### insert\_barriers @@ -125,9 +125,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -215,20 +215,44 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.QFT.unit "qiskit.circuit.library.QFT.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.QFT.duration "qiskit.circuit.library.QFT.duration") is specified in. ## Methods ### inverse - + Invert this circuit. **Parameters** @@ -246,7 +270,7 @@ $$ ### is\_inverse - + Whether the inverse Fourier transform is implemented. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.QuadraticForm.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.QuadraticForm.mdx index 0e0016cbb68..c1ac4cd7dc7 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.QuadraticForm.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.QuadraticForm.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.QuadraticForm # QuadraticForm - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Implements a quadratic form on binary variables encoded in qubit registers. @@ -57,7 +57,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -71,13 +71,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -91,7 +91,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -111,9 +111,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -253,14 +253,44 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.QuadraticForm.unit "qiskit.circuit.library.QuadraticForm.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.QuadraticForm.duration "qiskit.circuit.library.QuadraticForm.duration") is specified in. ## Methods ### required\_result\_qubits - + Get the number of required result qubits. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.QuantumVolume.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.QuantumVolume.mdx index a0eb8fe0f55..e1cbdbe8af8 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.QuantumVolume.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.QuantumVolume.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.QuantumVolume # QuantumVolume - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") A quantum volume model circuit. @@ -35,7 +35,7 @@ python_api_name: qiskit.circuit.library.QuantumVolume * **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** ([*Generator*](https://numpy.org/doc/stable/reference/random/generator.html#numpy.random.Generator "(in NumPy v1.26)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Random number generator or generator seed. + * **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. * **flatten** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `False` (the default), construct a circuit that contains a single instruction, which in turn has the actual volume structure. If `True`, construct the volume structure directly. @@ -44,7 +44,7 @@ python_api_name: qiskit.circuit.library.QuantumVolume ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -58,13 +58,13 @@ python_api_name: qiskit.circuit.library.QuantumVolume ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -78,7 +78,7 @@ python_api_name: qiskit.circuit.library.QuantumVolume ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -98,9 +98,9 @@ python_api_name: qiskit.circuit.library.QuantumVolume ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -240,7 +240,37 @@ python_api_name: qiskit.circuit.library.QuantumVolume ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.QuantumVolume.unit "qiskit.circuit.library.QuantumVolume.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.QuantumVolume.duration "qiskit.circuit.library.QuantumVolume.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.RC3XGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.RC3XGate.mdx index 824605c4a23..16c06ab9f1b 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.RC3XGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.RC3XGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RC3XGate # RC3XGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The simplified 3-controlled Toffoli gate. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.RCCXGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.RCCXGate.mdx index 0b517c029b2..f66b0a41600 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.RCCXGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.RCCXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RCCXGate # RCCXGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The simplified Toffoli gate, also referred to as Margolus gate. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.RGQFTMultiplier.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.RGQFTMultiplier.mdx index f9bf39c4643..fe8158f8826 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.RGQFTMultiplier.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.RGQFTMultiplier.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RGQFTMultiplier # RGQFTMultiplier - + Bases: `Multiplier` A QFT multiplication circuit to store product of two input registers out-of-place. @@ -45,7 +45,7 @@ python_api_name: qiskit.circuit.library.RGQFTMultiplier ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -59,13 +59,13 @@ python_api_name: qiskit.circuit.library.RGQFTMultiplier ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -79,7 +79,7 @@ python_api_name: qiskit.circuit.library.RGQFTMultiplier ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -99,9 +99,9 @@ python_api_name: qiskit.circuit.library.RGQFTMultiplier ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -261,7 +261,37 @@ python_api_name: qiskit.circuit.library.RGQFTMultiplier ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.RGQFTMultiplier.unit "qiskit.circuit.library.RGQFTMultiplier.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.RGQFTMultiplier.duration "qiskit.circuit.library.RGQFTMultiplier.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.RGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.RGate.mdx index e06d41de605..838ee78efa3 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.RGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.RGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RGate # RGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Rotation θ around the cos(φ)x + sin(φ)y axis. @@ -138,7 +138,7 @@ $$ ### inverse - + Invert this gate as: $r(θ, φ)^dagger = r(-θ, φ)$ **Parameters** @@ -156,7 +156,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.RVGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.RVGate.mdx index 7e1fa3607a1..bbff19b2ecf 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.RVGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.RVGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RVGate # RVGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Rotation around arbitrary rotation axis $\vec{v}$ where $\|\vec{v}\|_2$ is angle of rotation in radians. @@ -150,13 +150,13 @@ $$ ### inverse - + Invert this gate. ### to\_matrix - + Return a numpy.array for the R(v) gate. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.RXGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.RXGate.mdx index 904239c5809..533bd5d432a 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.RXGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.RXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RXGate # RXGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Single-qubit rotation about the X axis. @@ -138,7 +138,7 @@ $$ ### control - + Return a (multi-)controlled-RX gate. **Parameters** @@ -159,7 +159,7 @@ $$ ### inverse - + Return inverted RX gate. $RX(\lambda)^{\dagger} = RX(-\lambda)$ @@ -179,7 +179,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](#qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.RXXGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.RXXGate.mdx index 60612b4d371..fc62dd55125 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.RXXGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.RXXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RXXGate # RXXGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") A parametric 2-qubit $X \otimes X$ interaction (rotation about XX). @@ -164,7 +164,7 @@ $$ ### inverse - + Return inverse RXX gate (i.e. with the negative rotation angle). **Parameters** @@ -182,7 +182,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.RYGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.RYGate.mdx index bf9fa6c7df1..8c68030687d 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.RYGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.RYGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RYGate # RYGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Single-qubit rotation about the Y axis. @@ -138,7 +138,7 @@ $$ ### control - + Return a (multi-)controlled-RY gate. **Parameters** @@ -159,7 +159,7 @@ $$ ### inverse - + Return inverse RY gate. $RY(\lambda)^{\dagger} = RY(-\lambda)$ @@ -179,7 +179,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.RYYGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.RYYGate.mdx index 2eb5d10b0fd..abfd0fed9f0 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.RYYGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.RYYGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RYYGate # RYYGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") A parametric 2-qubit $Y \otimes Y$ interaction (rotation about YY). @@ -164,7 +164,7 @@ $$ ### inverse - + Return inverse RYY gate (i.e. with the negative rotation angle). **Parameters** @@ -182,7 +182,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.RZGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.RZGate.mdx index 99803f950bf..34d886d9f9c 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.RZGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.RZGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RZGate # RZGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Single-qubit rotation about the Z axis. @@ -148,7 +148,7 @@ $$ ### control - + Return a (multi-)controlled-RZ gate. **Parameters** @@ -169,7 +169,7 @@ $$ ### inverse - + Return inverted RZ gate $RZ(\lambda)^{\dagger} = RZ(-\lambda)$ @@ -189,7 +189,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.RZXGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.RZXGate.mdx index 1aa2c6dd417..38e59c2038b 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.RZXGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.RZXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RZXGate # RZXGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") A parametric 2-qubit $Z \otimes X$ interaction (rotation about ZX). @@ -204,7 +204,7 @@ $$ ### inverse - + Return inverse RZX gate (i.e. with the negative rotation angle). **Parameters** @@ -222,7 +222,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.RZZGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.RZZGate.mdx index d6023d55019..469872dd52e 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.RZZGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.RZZGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RZZGate # RZZGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") A parametric 2-qubit $Z \otimes Z$ interaction (rotation about ZZ). @@ -176,7 +176,7 @@ $$ ### inverse - + Return inverse RZZ gate (i.e. with the negative rotation angle). **Parameters** @@ -194,7 +194,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.RealAmplitudes.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.RealAmplitudes.mdx index 02f2d18240c..2f2597e9a87 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.RealAmplitudes.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.RealAmplitudes.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RealAmplitudes # RealAmplitudes - + Bases: [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.n_local.two_local.TwoLocal") The real-amplitudes 2-local circuit. @@ -117,7 +117,7 @@ python_api_name: qiskit.circuit.library.RealAmplitudes ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -131,7 +131,7 @@ python_api_name: qiskit.circuit.library.RealAmplitudes ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -167,7 +167,7 @@ python_api_name: qiskit.circuit.library.RealAmplitudes ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -207,9 +207,9 @@ python_api_name: qiskit.circuit.library.RealAmplitudes ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -369,13 +369,13 @@ python_api_name: qiskit.circuit.library.RealAmplitudes ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -397,5 +397,29 @@ python_api_name: qiskit.circuit.library.RealAmplitudes The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.RealAmplitudes.unit "qiskit.circuit.library.RealAmplitudes.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.RealAmplitudes.duration "qiskit.circuit.library.RealAmplitudes.duration") is specified in. + diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.SGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.SGate.mdx index c8f5a159b20..fdc7564f634 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.SGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.SGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.SGate # SGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") Single qubit S gate (Z\*\*0.5). @@ -141,7 +141,7 @@ $$ ### inverse - + Return inverse of S (SdgGate). **Parameters** @@ -159,7 +159,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.SXGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.SXGate.mdx index 81ee5e2a648..19da3f88187 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.SXGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.SXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.SXGate # SXGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The single-qubit Sqrt(X) gate ($\sqrt{X}$). @@ -147,7 +147,7 @@ $$ ### control - + Return a (multi-)controlled-SX gate. One control returns a CSX gate. @@ -170,7 +170,7 @@ $$ ### inverse - + Return inverse SX gate (i.e. SXdg). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.SXdgGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.SXdgGate.mdx index f556abf081d..8f3b6b7c8b3 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.SXdgGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.SXdgGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.SXdgGate # SXdgGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The inverse single-qubit Sqrt(X) gate. @@ -137,7 +137,7 @@ $$ ### inverse - + Return inverse SXdg gate (i.e. SX). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.SdgGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.SdgGate.mdx index f92ad800cab..24bbcadcdb2 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.SdgGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.SdgGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.SdgGate # SdgGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") Single qubit S-adjoint gate (\~Z\*\*0.5). @@ -141,7 +141,7 @@ $$ ### inverse - + Return inverse of Sdg (SGate). **Parameters** @@ -159,7 +159,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.StatePreparation.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.StatePreparation.mdx index 3c2f28c5b14..b4ca2e84c05 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.StatePreparation.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.StatePreparation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.StatePreparation # StatePreparation - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Complex amplitude state preparation. @@ -36,9 +36,11 @@ python_api_name: qiskit.circuit.library.StatePreparation [**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. + When a Statevector argument is passed the state is prepared based on the [`Isometry`](qiskit.circuit.library.Isometry "qiskit.circuit.library.Isometry") synthesis described in \[1]. - **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)] + **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). ## Attributes @@ -141,7 +143,7 @@ python_api_name: qiskit.circuit.library.StatePreparation ### broadcast\_arguments - + 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: @@ -190,13 +192,13 @@ python_api_name: qiskit.circuit.library.StatePreparation ### inverse - + Return inverted StatePreparation ### validate\_parameter - + StatePreparation instruction parameter can be str, int, float, and complex. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.SwapGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.SwapGate.mdx index be7c74c8e0b..e6a39f549e8 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.SwapGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.SwapGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.SwapGate # SwapGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The SWAP gate. @@ -146,7 +146,7 @@ $$ ### control - + Return a (multi-)controlled-SWAP gate. One control returns a CSWAP (Fredkin) gate. @@ -169,7 +169,7 @@ $$ ### inverse - + Return inverse Swap gate (itself). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.TGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.TGate.mdx index 715c8bee6b1..b1993cf3904 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.TGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.TGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.TGate # TGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") Single qubit T gate (Z\*\*0.25). @@ -141,7 +141,7 @@ $$ ### inverse - + Return inverse T gate (i.e. Tdg). **Parameters** @@ -159,7 +159,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.TdgGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.TdgGate.mdx index e53fcab4c55..725b6eb6534 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.TdgGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.TdgGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.TdgGate # TdgGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") Single qubit T-adjoint gate (\~Z\*\*0.25). @@ -141,7 +141,7 @@ $$ ### inverse - + Return inverse Tdg gate (i.e. T). **Parameters** @@ -159,7 +159,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.TwoLocal.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.TwoLocal.mdx index a3f627c4003..5178f553c55 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.TwoLocal.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.TwoLocal.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.TwoLocal # TwoLocal - + Bases: [`NLocal`](qiskit.circuit.library.NLocal "qiskit.circuit.library.n_local.n_local.NLocal") The two-local circuit. @@ -129,7 +129,7 @@ python_api_name: qiskit.circuit.library.TwoLocal ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -143,7 +143,7 @@ python_api_name: qiskit.circuit.library.TwoLocal ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -179,7 +179,7 @@ python_api_name: qiskit.circuit.library.TwoLocal ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -219,9 +219,9 @@ python_api_name: qiskit.circuit.library.TwoLocal ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -381,13 +381,13 @@ python_api_name: qiskit.circuit.library.TwoLocal ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -410,11 +410,35 @@ python_api_name: qiskit.circuit.library.TwoLocal The blocks in the rotation layers. + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.TwoLocal.unit "qiskit.circuit.library.TwoLocal.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.TwoLocal.duration "qiskit.circuit.library.TwoLocal.duration") is specified in. + + ## Methods ### get\_entangler\_map - + Overloading to handle the special case of 1 qubit where the entanglement are ignored. **Return type** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.U1Gate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.U1Gate.mdx index b89e7dfeb4c..886c7eff7f1 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.U1Gate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.U1Gate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.U1Gate # U1Gate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Single-qubit rotation about the Z axis. @@ -175,7 +175,7 @@ $$ ### control - + Return a (multi-)controlled-U1 gate. **Parameters** @@ -196,7 +196,7 @@ $$ ### inverse - + Return inverted U1 gate ($U1(\lambda)^{\dagger} = U1(-\lambda))$ **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.U2Gate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.U2Gate.mdx index aa9f85d5af6..5533b9d541f 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.U2Gate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.U2Gate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.U2Gate # U2Gate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Single-qubit rotation about the X+Z axis. @@ -174,7 +174,7 @@ $$ ### inverse - + Return inverted U2 gate. $U2(\phi, \lambda)^{\dagger} =U2(-\lambda-\pi, -\phi+\pi))$ diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.U3Gate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.U3Gate.mdx index 36099cb09bd..302d4195fca 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.U3Gate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.U3Gate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.U3Gate # U3Gate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Generic single-qubit rotation gate with 3 Euler angles. @@ -169,7 +169,7 @@ $$ ### control - + Return a (multi-)controlled-U3 gate. **Parameters** @@ -190,7 +190,7 @@ $$ ### inverse - + Return inverted U3 gate. $U3(\theta,\phi,\lambda)^{\dagger} =U3(-\theta,-\lambda,-\phi))$ diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.UCGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.UCGate.mdx index 70ccc0702db..b279855c4b5 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.UCGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.UCGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UCGate # UCGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Uniformly controlled gate (also called multiplexed gate). @@ -144,7 +144,7 @@ $$ ### 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. @@ -156,7 +156,7 @@ $$ ### validate\_parameter - + Uniformly controlled gate parameter has to be an ndarray. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.UCPauliRotGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.UCPauliRotGate.mdx index 41cf07c52d6..276a3cb3d15 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.UCPauliRotGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.UCPauliRotGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UCPauliRotGate # UCPauliRotGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Uniformly controlled Pauli rotations. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.UCRXGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.UCRXGate.mdx index 9749f619b74..46c4990bdc2 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.UCRXGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.UCRXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UCRXGate # UCRXGate - + Bases: [`UCPauliRotGate`](qiskit.circuit.library.UCPauliRotGate "qiskit.circuit.library.generalized_gates.uc_pauli_rot.UCPauliRotGate") Uniformly controlled Pauli-X rotations. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.UCRYGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.UCRYGate.mdx index 5a81ccdeeae..67c63a5167d 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.UCRYGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.UCRYGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UCRYGate # UCRYGate - + Bases: [`UCPauliRotGate`](qiskit.circuit.library.UCPauliRotGate "qiskit.circuit.library.generalized_gates.uc_pauli_rot.UCPauliRotGate") Uniformly controlled Pauli-Y rotations. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.UCRZGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.UCRZGate.mdx index e2992f0e4a1..a46817f85c6 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.UCRZGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.UCRZGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UCRZGate # UCRZGate - + Bases: [`UCPauliRotGate`](qiskit.circuit.library.UCPauliRotGate "qiskit.circuit.library.generalized_gates.uc_pauli_rot.UCPauliRotGate") Uniformly controlled Pauli-Z rotations. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.UGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.UGate.mdx index 2d69f37898e..08900b8ba47 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.UGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.UGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UGate # UGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Generic single-qubit rotation gate with 3 Euler angles. @@ -152,7 +152,7 @@ $$ ### control - + Return a (multi-)controlled-U gate. **Parameters** @@ -173,7 +173,7 @@ $$ ### inverse - + Return inverted U gate. $U(\theta,\phi,\lambda)^{\dagger} =U(-\theta,-\lambda,-\phi))$ diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.UnitaryGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.UnitaryGate.mdx index 49677cfb70e..54edf1cc58f 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.UnitaryGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.UnitaryGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UnitaryGate # UnitaryGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Class quantum gates specified by a unitary matrix. @@ -145,19 +145,19 @@ python_api_name: qiskit.circuit.library.UnitaryGate ### adjoint - + Return the adjoint of the unitary. ### conjugate - + Return the conjugate of the unitary. ### control - + Return controlled version of gate. **Parameters** @@ -178,19 +178,19 @@ python_api_name: qiskit.circuit.library.UnitaryGate ### inverse - + Return the adjoint of the unitary. ### transpose - + Return the transpose of the unitary. ### validate\_parameter - + Unitary gate parameter has to be an ndarray. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.UnitaryOverlap.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.UnitaryOverlap.mdx index 97e69e85955..0425d178c09 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.UnitaryOverlap.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.UnitaryOverlap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UnitaryOverlap # UnitaryOverlap - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Circuit that returns the overlap between two unitaries $U_2^{\dag} U_1$. @@ -63,7 +63,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -77,13 +77,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -97,7 +97,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -117,9 +117,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -259,7 +259,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.UnitaryOverlap.unit "qiskit.circuit.library.UnitaryOverlap.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.UnitaryOverlap.duration "qiskit.circuit.library.UnitaryOverlap.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.VBERippleCarryAdder.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.VBERippleCarryAdder.mdx index c276b12ade2..d30cd026ee5 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.VBERippleCarryAdder.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.VBERippleCarryAdder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.VBERippleCarryAdder # VBERippleCarryAdder - + Bases: `Adder` The VBE ripple carry adder \[1]. @@ -54,7 +54,7 @@ python_api_name: qiskit.circuit.library.VBERippleCarryAdder ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -68,13 +68,13 @@ python_api_name: qiskit.circuit.library.VBERippleCarryAdder ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -88,7 +88,7 @@ python_api_name: qiskit.circuit.library.VBERippleCarryAdder ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -108,9 +108,9 @@ python_api_name: qiskit.circuit.library.VBERippleCarryAdder ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -260,7 +260,37 @@ python_api_name: qiskit.circuit.library.VBERippleCarryAdder ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.VBERippleCarryAdder.unit "qiskit.circuit.library.VBERippleCarryAdder.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.VBERippleCarryAdder.duration "qiskit.circuit.library.VBERippleCarryAdder.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.WeightedAdder.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.WeightedAdder.mdx index d61e06e910c..b87b304ca48 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.WeightedAdder.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.WeightedAdder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.WeightedAdder # WeightedAdder - + Bases: `BlueprintCircuit` A circuit to compute the weighted sum of qubit registers. @@ -67,7 +67,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -81,7 +81,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -91,7 +91,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -111,9 +111,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -241,13 +241,13 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### weights @@ -259,5 +259,29 @@ $$ The weight for the qubit states. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.WeightedAdder.unit "qiskit.circuit.library.WeightedAdder.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.WeightedAdder.duration "qiskit.circuit.library.WeightedAdder.duration") is specified in. + diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.XGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.XGate.mdx index 5ebf5dce11d..bfbae4ea9f9 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.XGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.XGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.XGate # XGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The single-qubit Pauli-X gate ($\sigma_x$). @@ -156,7 +156,7 @@ $$ ### control - + Return a (multi-)controlled-X gate. One control returns a CX gate. Two controls returns a CCX gate. @@ -179,7 +179,7 @@ $$ ### inverse - + Return inverted X gate (itself). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.XOR.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.XOR.mdx index 9dd989331ee..d6ce25a47ae 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.XOR.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.XOR.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.XOR # XOR - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") An n\_qubit circuit for bitwise xor-ing the input with some integer `amount`. @@ -38,7 +38,7 @@ python_api_name: qiskit.circuit.library.XOR ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -52,13 +52,13 @@ python_api_name: qiskit.circuit.library.XOR ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -72,7 +72,7 @@ python_api_name: qiskit.circuit.library.XOR ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -92,9 +92,9 @@ python_api_name: qiskit.circuit.library.XOR ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -234,7 +234,37 @@ python_api_name: qiskit.circuit.library.XOR ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.XOR.unit "qiskit.circuit.library.XOR.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.XOR.duration "qiskit.circuit.library.XOR.duration") is specified in. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.XXMinusYYGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.XXMinusYYGate.mdx index ecfe1cbbdca..d0d43d71118 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.XXMinusYYGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.XXMinusYYGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.XXMinusYYGate # XXMinusYYGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") XX-YY interaction gate. @@ -174,7 +174,7 @@ $$ ### inverse - + Inverse gate. **Parameters** @@ -192,7 +192,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.XXPlusYYGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.XXPlusYYGate.mdx index 9c64498ed4a..373ae315a2f 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.XXPlusYYGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.XXPlusYYGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.XXPlusYYGate # XXPlusYYGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") XX+YY interaction gate. @@ -50,7 +50,6 @@ $$ q_1: ┤0 ├ └───────────────┘ ``` - $$ \newcommand{\rotationangle}{\frac{\theta}{2}} @@ -59,11 +58,14 @@ 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 & \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. @@ -174,7 +176,7 @@ $$ ### inverse - + Return inverse XX+YY gate (i.e. with the negative rotation angle and same phase angle). **Parameters** @@ -192,7 +194,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.YGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.YGate.mdx index 85c4494c303..165e5126159 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.YGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.YGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.YGate # YGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The single-qubit Pauli-Y gate ($\sigma_y$). @@ -156,7 +156,7 @@ $$ ### control - + Return a (multi-)controlled-Y gate. One control returns a CY gate. @@ -179,7 +179,7 @@ $$ ### inverse - + Return inverted Y gate ($Y^{\dagger} = Y$) **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.ZFeatureMap.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.ZFeatureMap.mdx index 16f1ce688bc..c36e9d30899 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.ZFeatureMap.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.ZFeatureMap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.ZFeatureMap # ZFeatureMap - + Bases: [`PauliFeatureMap`](qiskit.circuit.library.PauliFeatureMap "qiskit.circuit.library.data_preparation.pauli_feature_map.PauliFeatureMap") The first order Pauli Z-evolution circuit. @@ -91,7 +91,7 @@ python_api_name: qiskit.circuit.library.ZFeatureMap ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -105,7 +105,7 @@ python_api_name: qiskit.circuit.library.ZFeatureMap ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -145,7 +145,7 @@ python_api_name: qiskit.circuit.library.ZFeatureMap ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -185,9 +185,9 @@ python_api_name: qiskit.circuit.library.ZFeatureMap ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -347,13 +347,13 @@ python_api_name: qiskit.circuit.library.ZFeatureMap ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -375,5 +375,29 @@ python_api_name: qiskit.circuit.library.ZFeatureMap The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.ZFeatureMap.unit "qiskit.circuit.library.ZFeatureMap.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.ZFeatureMap.duration "qiskit.circuit.library.ZFeatureMap.duration") is specified in. + diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.ZGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.ZGate.mdx index e4f4b8f03df..7cb22bd7752 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.ZGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.ZGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.ZGate # ZGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The single-qubit Pauli-Z gate ($\sigma_z$). @@ -156,7 +156,7 @@ $$ ### control - + Return a (multi-)controlled-Z gate. One control returns a CZ gate. @@ -179,7 +179,7 @@ $$ ### inverse - + Return inverted Z gate (itself). **Parameters** @@ -197,7 +197,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.ZZFeatureMap.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.ZZFeatureMap.mdx index 6a4f2a5d0cc..d77cfc78331 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.ZZFeatureMap.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.ZZFeatureMap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap # ZZFeatureMap - + Bases: [`PauliFeatureMap`](qiskit.circuit.library.PauliFeatureMap "qiskit.circuit.library.data_preparation.pauli_feature_map.PauliFeatureMap") Second-order Pauli-Z evolution circuit. @@ -96,7 +96,7 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -110,7 +110,7 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -150,7 +150,7 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -190,9 +190,9 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -352,13 +352,13 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -380,5 +380,29 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.ZZFeatureMap.unit "qiskit.circuit.library.ZZFeatureMap.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.ZZFeatureMap.duration "qiskit.circuit.library.ZZFeatureMap.duration") is specified in. + diff --git a/docs/api/qiskit/dev/qiskit.circuit.library.iSwapGate.mdx b/docs/api/qiskit/dev/qiskit.circuit.library.iSwapGate.mdx index 63e428980a8..bfe0982d4b8 100644 --- a/docs/api/qiskit/dev/qiskit.circuit.library.iSwapGate.mdx +++ b/docs/api/qiskit/dev/qiskit.circuit.library.iSwapGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.iSwapGate # iSwapGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") iSWAP gate. @@ -169,7 +169,7 @@ $$ ### power - + Raise this gate to the power of `exponent`. Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. diff --git a/docs/api/qiskit/dev/qiskit.dagcircuit.DAGCircuit.mdx b/docs/api/qiskit/dev/qiskit.dagcircuit.DAGCircuit.mdx index a8a11d2f957..aa482f0e967 100644 --- a/docs/api/qiskit/dev/qiskit.dagcircuit.DAGCircuit.mdx +++ b/docs/api/qiskit/dev/qiskit.dagcircuit.DAGCircuit.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit # DAGCircuit - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Quantum circuit as a directed acyclic graph. @@ -75,7 +75,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### add\_calibration - + Register a low-level, custom pulse definition for the given gate. **Parameters** @@ -92,7 +92,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### add\_captured\_var - + Add a captured variable to the circuit. **Parameters** @@ -102,19 +102,19 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### add\_clbits - + Add individual clbit wires. ### add\_creg - + Add all wires in a classical register. ### add\_declared\_var - + Add a declared local variable to the circuit. **Parameters** @@ -124,7 +124,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### add\_input\_var - + Add an input variable to the circuit. **Parameters** @@ -134,25 +134,25 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### add\_qreg - + Add all wires in a quantum register. ### add\_qubits - + Add individual qubit wires. ### ancestors - + Returns set of the ancestors of a node as DAGOpNodes and DAGInNodes. ### apply\_operation\_back - + Apply an operation to the output of the circuit. **Parameters** @@ -177,7 +177,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### apply\_operation\_front - + Apply an operation to the input of the circuit. **Parameters** @@ -202,41 +202,41 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### bfs\_successors - + 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 - + Returns iterator of the predecessors of a node that are connected by a classical edge as DAGOpNodes and DAGInNodes. ### classical\_successors - + Returns iterator of the successors of a node that are connected by a classical edge as DAGOpNodes and DAGInNodes. ### collect\_1q\_runs - + Return a set of non-conditional runs of 1q “op” nodes. **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)")\[[qiskit.dagcircuit.dagnode.DAGOpNode](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.dagnode.DAGOpNode")]] + [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)")\[[qiskit.\_accelerate.circuit.DAGOpNode](qiskit.dagcircuit.DAGOpNode "qiskit._accelerate.circuit.DAGOpNode")]] ### collect\_2q\_runs - + Return a set of non-conditional runs of 2q “op” nodes. ### collect\_runs - + 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. @@ -246,7 +246,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### compose - + 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. @@ -277,7 +277,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### copy\_empty\_like - + Return a copy of self with the same structure but empty. **That structure includes:** @@ -317,7 +317,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### count\_ops - + Count the occurrences of operation names. **Parameters** @@ -335,7 +335,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### count\_ops\_longest\_path - + Count the occurrences of operation names on the longest path. Returns a dictionary of counts keyed on the operation name. @@ -343,7 +343,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### depth - + 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** @@ -366,13 +366,13 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### descendants - + Returns set of the descendants of a node as DAGOpNodes and DAGOutNodes. ### draw - + 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. @@ -394,7 +394,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### edges - + 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. @@ -414,7 +414,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### find\_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** @@ -438,13 +438,13 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### front\_layer - + Return a list of op nodes in the first layer of this dag. ### gate\_nodes - + Get the list of gate nodes in the dag. **Returns** @@ -458,13 +458,13 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### has\_calibration\_for - + 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. ### has\_var - + Is this realtime variable in the DAG? **Parameters** @@ -478,7 +478,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### idle\_wires - + Return idle wires. **Parameters** @@ -496,43 +496,43 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### is\_predecessor - + Checks if a second node is in the predecessors of node. ### is\_successor - + Checks if a second node is in the successors of node. ### iter\_captured\_vars - + Iterable over the captured classical variables tracked by the circuit. ### iter\_declared\_vars - + Iterable over the declared local classical variables tracked by the circuit. ### iter\_input\_vars - + Iterable over the input classical variables tracked by the circuit. ### iter\_vars - + Iterable over all the classical variables tracked by the circuit. ### 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}. @@ -548,31 +548,31 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### longest\_path - + Returns the longest path in the dag as a list of DAGOpNodes, DAGInNodes, and DAGOutNodes. ### multi\_qubit\_ops - + Get list of 3+ qubit operations. Ignore directives like snapshot and barrier. ### multigraph\_layers - + Yield layers of the multigraph. ### named\_nodes - + Get the set of “op” nodes with the given name. ### node - + Get the node in the dag. **Parameters** @@ -590,7 +590,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### nodes - + Iterator for node values. **Yields** @@ -600,7 +600,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### nodes\_on\_wire - + Iterator for nodes that affect a given wire. **Parameters** @@ -619,25 +619,25 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### num\_clbits - + Return the total number of classical bits used by the circuit. ### 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 - + Compute how many components the circuit can decompose into. ### op\_nodes - + Get the list of “op” nodes in the dag. **Parameters** @@ -656,31 +656,31 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### op\_predecessors - + Returns the iterator of “op” predecessors of a node in the dag. ### op\_successors - + Returns iterator of “op” successors of a node in the dag. ### predecessors - + Returns iterator of the predecessors of a node as DAGOpNodes and DAGInNodes. ### properties - + Return a dictionary of circuit properties. ### quantum\_causal\_cone - + 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. @@ -702,31 +702,31 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### quantum\_predecessors - + Returns iterator of the predecessors of a node that are connected by a quantum edge as DAGOpNodes and DAGInNodes. ### quantum\_successors - + 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 operation nodes with the given name. ### remove\_ancestors\_of - + Remove all of the ancestor operation nodes of node. ### remove\_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** @@ -740,7 +740,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### remove\_cregs - + Remove classical registers from the circuit, leaving underlying bits in place. **Raises** @@ -751,25 +751,25 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### remove\_descendants\_of - + Remove all of the descendant operation nodes of node. ### remove\_nonancestors\_of - + Remove all of the non-ancestors operation nodes of node. ### remove\_nondescendants\_of - + Remove all of the non-descendants operation nodes of node. ### remove\_op\_node - + Remove an operation node n. Add edges from predecessors to successors. @@ -777,7 +777,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### remove\_qregs - + Remove classical registers from the circuit, leaving underlying bits in place. **Raises** @@ -788,7 +788,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### remove\_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** @@ -802,7 +802,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### replace\_block\_with\_op - + 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. @@ -829,7 +829,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### reverse\_ops - + Reverse the operations in the `self` circuit. **Returns** @@ -843,7 +843,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### separable\_circuits - + Decompose the circuit into sets of qubits with no gates connecting them. **Parameters** @@ -866,7 +866,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### 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(). @@ -878,7 +878,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### size - + 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** @@ -900,7 +900,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### substitute\_node - + 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** @@ -926,7 +926,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### substitute\_node\_with\_dag - + Replace one node with dag. **Parameters** @@ -958,13 +958,13 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### successors - + Returns iterator of the successors of a node as DAGOpNodes and DAGOutNodes. ### swap\_nodes - + Swap connected nodes e.g. due to commutation. **Parameters** @@ -979,7 +979,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### topological\_nodes - + Yield nodes in topological order. **Parameters** @@ -997,7 +997,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### topological\_op\_nodes - + Yield op nodes in topological order. Allowed to pass in specific key to break ties in top order @@ -1017,13 +1017,13 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### two\_qubit\_ops - + Get list of 2 qubit operations. Ignore directives like snapshot and barrier. ### 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/dev/qiskit.dagcircuit.DAGDepNode.mdx b/docs/api/qiskit/dev/qiskit.dagcircuit.DAGDepNode.mdx index 34f214cfc10..40adbd75747 100644 --- a/docs/api/qiskit/dev/qiskit.dagcircuit.DAGDepNode.mdx +++ b/docs/api/qiskit/dev/qiskit.dagcircuit.DAGDepNode.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.dagcircuit.DAGDepNode # DAGDepNode - + 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(). @@ -85,13 +85,13 @@ python_api_name: qiskit.dagcircuit.DAGDepNode ### copy - + Function to copy a DAGDepNode object. :returns: a copy of a DAGDepNode object. :rtype: DAGDepNode ### semantic\_eq - + Check if DAG nodes are considered equivalent, e.g., as a node\_match for nx.is\_isomorphic. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.dagcircuit.DAGDependency.mdx b/docs/api/qiskit/dev/qiskit.dagcircuit.DAGDependency.mdx index e95472047e6..7105ea04dd6 100644 --- a/docs/api/qiskit/dev/qiskit.dagcircuit.DAGDependency.mdx +++ b/docs/api/qiskit/dev/qiskit.dagcircuit.DAGDependency.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency # DAGDependency - + 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). @@ -57,19 +57,19 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### add\_clbits - + Add individual clbit wires. ### add\_creg - + Add clbits in a classical register. ### add\_op\_node - + Add a DAGDepNode to the graph and update the edges. **Parameters** @@ -81,31 +81,31 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### add\_qreg - + Add qubits in a quantum register. ### add\_qubits - + Add individual qubit wires. ### copy - + Function to copy a DAGDependency object. :returns: a copy of a DAGDependency object. :rtype: DAGDependency ### depth - + Return the circuit depth. :returns: the circuit depth :rtype: int ### direct\_predecessors - + Direct predecessors id of a given node as sorted list. **Parameters** @@ -123,7 +123,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### direct\_successors - + Direct successors id of a given node as sorted list. **Parameters** @@ -141,7 +141,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### draw - + 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. @@ -163,7 +163,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### get\_all\_edges - + Enumeration of all edges. **Returns** @@ -177,7 +177,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### get\_edges - + Edge enumeration between two nodes through method get\_all\_edge\_data. **Parameters** @@ -196,7 +196,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### get\_in\_edges - + Enumeration of all incoming edges for a given node. **Parameters** @@ -214,7 +214,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### get\_node - + **Parameters** **node\_id** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – label of considered node. @@ -230,7 +230,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### get\_nodes - + **Returns** iterator over all the nodes. @@ -242,7 +242,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### get\_out\_edges - + Enumeration of all outgoing edges for a given node. **Parameters** @@ -260,7 +260,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### predecessors - + Predecessors id of a given node as sorted list. **Parameters** @@ -278,7 +278,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### replace\_block\_with\_op - + 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. @@ -299,13 +299,13 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### size - + Returns the number of gates in the circuit ### successors - + Successors id of a given node as sorted list. **Parameters** @@ -323,13 +323,13 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### to\_retworkx - + Returns the DAGDependency in retworkx format. ### topological\_nodes - + Yield nodes in topological order. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.dagcircuit.DAGInNode.mdx b/docs/api/qiskit/dev/qiskit.dagcircuit.DAGInNode.mdx index f7d836024c4..c0f8cf70800 100644 --- a/docs/api/qiskit/dev/qiskit.dagcircuit.DAGInNode.mdx +++ b/docs/api/qiskit/dev/qiskit.dagcircuit.DAGInNode.mdx @@ -8,28 +8,26 @@ python_api_name: qiskit.dagcircuit.DAGInNode # DAGInNode - - Bases: [`DAGNode`](qiskit.dagcircuit.DAGNode "qiskit.dagcircuit.dagnode.DAGNode") + + Bases: [`DAGNode`](qiskit.dagcircuit.DAGNode "qiskit._accelerate.circuit.DAGNode") Object to represent an incoming wire node in the DAGCircuit. - Create an incoming node - ## Attributes - ### wire - - - ### sort\_key + ### wire + + + ## Methods ### semantic\_eq - + 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)"). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.dagcircuit.DAGNode.mdx b/docs/api/qiskit/dev/qiskit.dagcircuit.DAGNode.mdx index 9db81fb6cc0..80c37c23a8f 100644 --- a/docs/api/qiskit/dev/qiskit.dagcircuit.DAGNode.mdx +++ b/docs/api/qiskit/dev/qiskit.dagcircuit.DAGNode.mdx @@ -8,18 +8,16 @@ python_api_name: qiskit.dagcircuit.DAGNode # DAGNode - + 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 - + 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)"). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.dagcircuit.DAGOpNode.mdx b/docs/api/qiskit/dev/qiskit.dagcircuit.DAGOpNode.mdx index f3893daa61d..b6e931fe368 100644 --- a/docs/api/qiskit/dev/qiskit.dagcircuit.DAGOpNode.mdx +++ b/docs/api/qiskit/dev/qiskit.dagcircuit.DAGOpNode.mdx @@ -8,15 +8,23 @@ python_api_name: qiskit.dagcircuit.DAGOpNode # DAGOpNode - - Bases: [`DAGNode`](qiskit.dagcircuit.DAGNode "qiskit.dagcircuit.dagnode.DAGNode") + + Bases: [`DAGNode`](qiskit.dagcircuit.DAGNode "qiskit._accelerate.circuit.DAGNode") Object to represent an Instruction at a node in the DAGCircuit. - Create an Instruction node - ## Attributes + ### cargs + + + + ### name + + + Returns the Instruction name corresponding to the op for this node + + ### op @@ -25,25 +33,15 @@ python_api_name: qiskit.dagcircuit.DAGOpNode - ### cargs - - - ### sort\_key - ### name - - - Returns the Instruction name corresponding to the op for this node - - ## Methods ### semantic\_eq - + 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)"). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.dagcircuit.DAGOutNode.mdx b/docs/api/qiskit/dev/qiskit.dagcircuit.DAGOutNode.mdx index 2173bbcd59b..8391a11f1ed 100644 --- a/docs/api/qiskit/dev/qiskit.dagcircuit.DAGOutNode.mdx +++ b/docs/api/qiskit/dev/qiskit.dagcircuit.DAGOutNode.mdx @@ -8,28 +8,26 @@ python_api_name: qiskit.dagcircuit.DAGOutNode # DAGOutNode - - Bases: [`DAGNode`](qiskit.dagcircuit.DAGNode "qiskit.dagcircuit.dagnode.DAGNode") + + Bases: [`DAGNode`](qiskit.dagcircuit.DAGNode "qiskit._accelerate.circuit.DAGNode") Object to represent an outgoing wire node in the DAGCircuit. - Create an outgoing node - ## Attributes - ### wire - - - ### sort\_key + ### wire + + + ## Methods ### semantic\_eq - + 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)"). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.passmanager.BaseController.mdx b/docs/api/qiskit/dev/qiskit.passmanager.BaseController.mdx index 84543c0611b..a2be5f0736e 100644 --- a/docs/api/qiskit/dev/qiskit.passmanager.BaseController.mdx +++ b/docs/api/qiskit/dev/qiskit.passmanager.BaseController.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.BaseController # BaseController - + Bases: `Task`, [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Base class of controller. @@ -25,7 +25,7 @@ python_api_name: qiskit.passmanager.BaseController ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -45,7 +45,7 @@ python_api_name: qiskit.passmanager.BaseController ### iter\_tasks - + 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. diff --git a/docs/api/qiskit/dev/qiskit.passmanager.BasePassManager.mdx b/docs/api/qiskit/dev/qiskit.passmanager.BasePassManager.mdx index 8a55d5c2cd2..a594982d33b 100644 --- a/docs/api/qiskit/dev/qiskit.passmanager.BasePassManager.mdx +++ b/docs/api/qiskit/dev/qiskit.passmanager.BasePassManager.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.BasePassManager # BasePassManager - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Pass manager base class. @@ -24,7 +24,7 @@ python_api_name: qiskit.passmanager.BasePassManager ### append - + Append tasks to the schedule of passes. **Parameters** @@ -38,7 +38,7 @@ python_api_name: qiskit.passmanager.BasePassManager ### remove - + Removes a particular pass in the scheduler. **Parameters** @@ -52,7 +52,7 @@ python_api_name: qiskit.passmanager.BasePassManager ### replace - + Replace a particular pass in the scheduler. **Parameters** @@ -68,7 +68,7 @@ python_api_name: qiskit.passmanager.BasePassManager ### run - + Run all the passes on the specified `in_programs`. **Parameters** @@ -116,7 +116,7 @@ python_api_name: qiskit.passmanager.BasePassManager ### 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** diff --git a/docs/api/qiskit/dev/qiskit.passmanager.ConditionalController.mdx b/docs/api/qiskit/dev/qiskit.passmanager.ConditionalController.mdx index eb6291d972b..901153a780f 100644 --- a/docs/api/qiskit/dev/qiskit.passmanager.ConditionalController.mdx +++ b/docs/api/qiskit/dev/qiskit.passmanager.ConditionalController.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.ConditionalController # ConditionalController - + 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. @@ -31,7 +31,7 @@ python_api_name: qiskit.passmanager.ConditionalController ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -51,7 +51,7 @@ python_api_name: qiskit.passmanager.ConditionalController ### iter\_tasks - + 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. diff --git a/docs/api/qiskit/dev/qiskit.passmanager.DoWhileController.mdx b/docs/api/qiskit/dev/qiskit.passmanager.DoWhileController.mdx index d4deebaaab0..4ffc728a518 100644 --- a/docs/api/qiskit/dev/qiskit.passmanager.DoWhileController.mdx +++ b/docs/api/qiskit/dev/qiskit.passmanager.DoWhileController.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.DoWhileController # DoWhileController - + 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`. @@ -33,7 +33,7 @@ python_api_name: qiskit.passmanager.DoWhileController ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -53,7 +53,7 @@ python_api_name: qiskit.passmanager.DoWhileController ### iter\_tasks - + 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. diff --git a/docs/api/qiskit/dev/qiskit.passmanager.FlowControllerLinear.mdx b/docs/api/qiskit/dev/qiskit.passmanager.FlowControllerLinear.mdx index 4a1a321a85e..db709c04427 100644 --- a/docs/api/qiskit/dev/qiskit.passmanager.FlowControllerLinear.mdx +++ b/docs/api/qiskit/dev/qiskit.passmanager.FlowControllerLinear.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.FlowControllerLinear # FlowControllerLinear - + Bases: [`BaseController`](qiskit.passmanager.BaseController "qiskit.passmanager.base_tasks.BaseController") A standard flow controller that runs tasks one after the other. @@ -31,7 +31,7 @@ python_api_name: qiskit.passmanager.FlowControllerLinear ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -51,7 +51,7 @@ python_api_name: qiskit.passmanager.FlowControllerLinear ### iter\_tasks - + 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. diff --git a/docs/api/qiskit/dev/qiskit.passmanager.GenericPass.mdx b/docs/api/qiskit/dev/qiskit.passmanager.GenericPass.mdx index 02d3a2aa744..23535895589 100644 --- a/docs/api/qiskit/dev/qiskit.passmanager.GenericPass.mdx +++ b/docs/api/qiskit/dev/qiskit.passmanager.GenericPass.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.GenericPass # GenericPass - + 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. @@ -19,7 +19,7 @@ python_api_name: qiskit.passmanager.GenericPass ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -39,7 +39,7 @@ python_api_name: qiskit.passmanager.GenericPass ### name - + Name of the pass. **Return type** @@ -49,7 +49,7 @@ python_api_name: qiskit.passmanager.GenericPass ### run - + Run optimization task. **Parameters** @@ -67,7 +67,7 @@ python_api_name: qiskit.passmanager.GenericPass ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.passmanager.PassManagerState.mdx b/docs/api/qiskit/dev/qiskit.passmanager.PassManagerState.mdx index 82171b02d38..76982798d58 100644 --- a/docs/api/qiskit/dev/qiskit.passmanager.PassManagerState.mdx +++ b/docs/api/qiskit/dev/qiskit.passmanager.PassManagerState.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.PassManagerState # PassManagerState - + 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. diff --git a/docs/api/qiskit/dev/qiskit.passmanager.PropertySet.mdx b/docs/api/qiskit/dev/qiskit.passmanager.PropertySet.mdx index ce19abd3eb2..c4661ec52a7 100644 --- a/docs/api/qiskit/dev/qiskit.passmanager.PropertySet.mdx +++ b/docs/api/qiskit/dev/qiskit.passmanager.PropertySet.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.PropertySet # PropertySet - + Bases: [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") A default dictionary-like object. diff --git a/docs/api/qiskit/dev/qiskit.passmanager.WorkflowStatus.mdx b/docs/api/qiskit/dev/qiskit.passmanager.WorkflowStatus.mdx index b818a9f5c47..4123c1f483b 100644 --- a/docs/api/qiskit/dev/qiskit.passmanager.WorkflowStatus.mdx +++ b/docs/api/qiskit/dev/qiskit.passmanager.WorkflowStatus.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.WorkflowStatus # WorkflowStatus - + 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. diff --git a/docs/api/qiskit/dev/qiskit.primitives.BackendEstimator.mdx b/docs/api/qiskit/dev/qiskit.primitives.BackendEstimator.mdx index 5ca00bd6325..91443fe973d 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.BackendEstimator.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.BackendEstimator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BackendEstimator # BackendEstimator - + Bases: [`BaseEstimatorV1`](qiskit.primitives.BaseEstimatorV1 "qiskit.primitives.base.base_estimator.BaseEstimatorV1")\[[`PrimitiveJob`](qiskit.primitives.PrimitiveJob "qiskit.primitives.primitive_job.PrimitiveJob")\[[`EstimatorResult`](qiskit.primitives.EstimatorResult "qiskit.primitives.base.estimator_result.EstimatorResult")]] Evaluates expectation value using Pauli rotation gates. @@ -69,7 +69,7 @@ python_api_name: qiskit.primitives.BackendEstimator ### run - + 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 @@ -113,7 +113,7 @@ python_api_name: qiskit.primitives.BackendEstimator ### set\_options - + Set options values for the estimator. **Parameters** @@ -123,7 +123,7 @@ python_api_name: qiskit.primitives.BackendEstimator ### set\_transpile\_options - + Set the transpiler options for transpiler. :param \*\*fields: The fields to update the options diff --git a/docs/api/qiskit/dev/qiskit.primitives.BackendEstimatorV2.mdx b/docs/api/qiskit/dev/qiskit.primitives.BackendEstimatorV2.mdx index df48f7a7488..e89eec255af 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.BackendEstimatorV2.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.BackendEstimatorV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BackendEstimatorV2 # BackendEstimatorV2 - + Bases: [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.base.base_estimator.BaseEstimatorV2") Evaluates expectation values for provided quantum circuit and observable combinations @@ -48,7 +48,7 @@ python_api_name: qiskit.primitives.BackendEstimatorV2 ### run - + Estimate expectation values for each provided pub (Primitive Unified Bloc). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.primitives.BackendSampler.mdx b/docs/api/qiskit/dev/qiskit.primitives.BackendSampler.mdx index 9c5bf541423..272871811af 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.BackendSampler.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.BackendSampler.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BackendSampler # BackendSampler - + Bases: [`BaseSamplerV1`](qiskit.primitives.BaseSamplerV1 "qiskit.primitives.base.base_sampler.BaseSamplerV1")\[[`PrimitiveJob`](qiskit.primitives.PrimitiveJob "qiskit.primitives.primitive_job.PrimitiveJob")\[[`SamplerResult`](qiskit.primitives.SamplerResult "qiskit.primitives.base.sampler_result.SamplerResult")]] A `BaseSampler` implementation that provides an interface for leveraging the sampler interface from any backend. @@ -76,7 +76,7 @@ python_api_name: qiskit.primitives.BackendSampler ### run - + Run the job of the sampling of bitstrings. **Parameters** @@ -100,7 +100,7 @@ python_api_name: qiskit.primitives.BackendSampler ### set\_options - + Set options values for the estimator. **Parameters** @@ -110,7 +110,7 @@ python_api_name: qiskit.primitives.BackendSampler ### set\_transpile\_options - + Set the transpiler options for transpiler. :param \*\*fields: The fields to update the options. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.primitives.BackendSamplerV2.mdx b/docs/api/qiskit/dev/qiskit.primitives.BackendSamplerV2.mdx index 30ea92a6d77..5dce8c43b4a 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.BackendSamplerV2.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.BackendSamplerV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BackendSamplerV2 # BackendSamplerV2 - + Bases: [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.base.base_sampler.BaseSamplerV2") Evaluates bitstrings for provided quantum circuits @@ -51,7 +51,7 @@ python_api_name: qiskit.primitives.BackendSamplerV2 ### run - + Run and collect samples from each pub. **Parameters** @@ -65,7 +65,7 @@ python_api_name: qiskit.primitives.BackendSamplerV2 **Return type** - [PrimitiveJob](qiskit.primitives.PrimitiveJob "qiskit.primitives.PrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[SamplerPubResult]] + [PrimitiveJob](qiskit.primitives.PrimitiveJob "qiskit.primitives.PrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[[SamplerPubResult](qiskit.primitives.SamplerPubResult "qiskit.primitives.SamplerPubResult")]] diff --git a/docs/api/qiskit/dev/qiskit.primitives.BaseEstimator.mdx b/docs/api/qiskit/dev/qiskit.primitives.BaseEstimator.mdx index 256672acf78..6065c8cc59f 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.BaseEstimator.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.BaseEstimator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BaseEstimator # BaseEstimator - + alias of [`BaseEstimatorV1`](qiskit.primitives.BaseEstimatorV1 "qiskit.primitives.base.base_estimator.BaseEstimatorV1") diff --git a/docs/api/qiskit/dev/qiskit.primitives.BaseEstimatorV1.mdx b/docs/api/qiskit/dev/qiskit.primitives.BaseEstimatorV1.mdx index a60feccf566..af333e2200d 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.BaseEstimatorV1.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.BaseEstimatorV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BaseEstimatorV1 # BaseEstimatorV1 - + Bases: `BasePrimitive`, [`Generic`](https://docs.python.org/3/library/typing.html#typing.Generic "(in Python v3.12)")\[`T`] Estimator V1 base class. @@ -82,7 +82,7 @@ $$ ### run - + 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 @@ -126,7 +126,7 @@ $$ ### set\_options - + Set options values for the estimator. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.primitives.BaseEstimatorV2.mdx b/docs/api/qiskit/dev/qiskit.primitives.BaseEstimatorV2.mdx index bcaa16b5fa6..6f6ba7bcd10 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.BaseEstimatorV2.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.BaseEstimatorV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BaseEstimatorV2 # BaseEstimatorV2 - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Estimator V2 base class. @@ -21,7 +21,7 @@ python_api_name: qiskit.primitives.BaseEstimatorV2 ### run - + Estimate expectation values for each provided pub (Primitive Unified Bloc). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.primitives.BasePrimitiveJob.mdx b/docs/api/qiskit/dev/qiskit.primitives.BasePrimitiveJob.mdx index 812f9d80f40..5634958834e 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.BasePrimitiveJob.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.BasePrimitiveJob.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BasePrimitiveJob # BasePrimitiveJob - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)"), [`Generic`](https://docs.python.org/3/library/typing.html#typing.Generic "(in Python v3.12)")\[`ResultT`, `StatusT`] Primitive job abstract base class. @@ -24,13 +24,13 @@ python_api_name: qiskit.primitives.BasePrimitiveJob ### cancel - + Attempt to cancel the job. ### cancelled - + Return whether the job has been cancelled. **Return type** @@ -40,7 +40,7 @@ python_api_name: qiskit.primitives.BasePrimitiveJob ### done - + Return whether the job has successfully run. **Return type** @@ -50,7 +50,7 @@ python_api_name: qiskit.primitives.BasePrimitiveJob ### in\_final\_state - + Return whether the job is in a final job state such as `DONE` or `ERROR`. **Return type** @@ -60,7 +60,7 @@ python_api_name: qiskit.primitives.BasePrimitiveJob ### job\_id - + Return a unique id identifying the job. **Return type** @@ -70,7 +70,7 @@ python_api_name: qiskit.primitives.BasePrimitiveJob ### result - + Return the results of the job. **Return type** @@ -80,7 +80,7 @@ python_api_name: qiskit.primitives.BasePrimitiveJob ### running - + Return whether the job is actively running. **Return type** @@ -90,7 +90,7 @@ python_api_name: qiskit.primitives.BasePrimitiveJob ### status - + Return the status of the job. **Return type** diff --git a/docs/api/qiskit/dev/qiskit.primitives.BaseSampler.mdx b/docs/api/qiskit/dev/qiskit.primitives.BaseSampler.mdx index 85e26d11ddb..fbd27621848 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.BaseSampler.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.BaseSampler.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BaseSampler # BaseSampler - + alias of [`BaseSamplerV1`](qiskit.primitives.BaseSamplerV1 "qiskit.primitives.base.base_sampler.BaseSamplerV1") diff --git a/docs/api/qiskit/dev/qiskit.primitives.BaseSamplerV1.mdx b/docs/api/qiskit/dev/qiskit.primitives.BaseSamplerV1.mdx index d73a68a321f..a7f232ba768 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.BaseSamplerV1.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.BaseSamplerV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BaseSamplerV1 # BaseSamplerV1 - + Bases: `BasePrimitive`, [`Generic`](https://docs.python.org/3/library/typing.html#typing.Generic "(in Python v3.12)")\[`T`] Sampler V1 base class @@ -81,7 +81,7 @@ python_api_name: qiskit.primitives.BaseSamplerV1 ### run - + Run the job of the sampling of bitstrings. **Parameters** @@ -105,7 +105,7 @@ python_api_name: qiskit.primitives.BaseSamplerV1 ### set\_options - + Set options values for the estimator. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.primitives.BaseSamplerV2.mdx b/docs/api/qiskit/dev/qiskit.primitives.BaseSamplerV2.mdx index c43b8ed6502..c971ff942f8 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.BaseSamplerV2.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.BaseSamplerV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BaseSamplerV2 # BaseSamplerV2 - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Sampler V2 base class. @@ -21,7 +21,7 @@ python_api_name: qiskit.primitives.BaseSamplerV2 ### run - + Run and collect samples from each pub. **Parameters** @@ -35,7 +35,7 @@ python_api_name: qiskit.primitives.BaseSamplerV2 **Return type** - [BasePrimitiveJob](qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[SamplerPubResult]] + [BasePrimitiveJob](qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[[SamplerPubResult](qiskit.primitives.SamplerPubResult "qiskit.primitives.SamplerPubResult")]] diff --git a/docs/api/qiskit/dev/qiskit.primitives.BitArray.mdx b/docs/api/qiskit/dev/qiskit.primitives.BitArray.mdx index c9a4a42e6d4..6095baf293f 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.BitArray.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.BitArray.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BitArray # BitArray - + Bases: `ShapedMixin` Stores an array of bit values. @@ -65,7 +65,7 @@ python_api_name: qiskit.primitives.BitArray ### bitcount - + Compute the number of ones appearing in the binary representation of each shot. **Returns** @@ -79,7 +79,7 @@ python_api_name: qiskit.primitives.BitArray ### concatenate - + Join a sequence of bit arrays along an existing axis. **Parameters** @@ -105,7 +105,7 @@ python_api_name: qiskit.primitives.BitArray ### concatenate\_bits - + Join a sequence of bit arrays along the bits axis. @@ -133,7 +133,7 @@ python_api_name: qiskit.primitives.BitArray ### concatenate\_shots - + Join a sequence of bit arrays along the shots axis. **Parameters** @@ -157,7 +157,7 @@ python_api_name: qiskit.primitives.BitArray ### expectation\_values - + Compute the expectation values of the provided observables, broadcasted against this bit array. @@ -188,7 +188,7 @@ python_api_name: qiskit.primitives.BitArray ### from\_bool\_array - + Construct a new bit array from an array of bools. **Parameters** @@ -207,7 +207,7 @@ python_api_name: qiskit.primitives.BitArray ### from\_counts - + Construct a new bit array from one or more `Counts`-like objects. The `counts` can have keys that are (uniformly) integers, hexstrings, or bitstrings. Their values represent numbers of occurrences of that value. @@ -233,7 +233,7 @@ python_api_name: qiskit.primitives.BitArray ### from\_samples - + Construct a new bit array from an iterable of bitstrings, hexstrings, or integers. All samples are assumed to be integers if the first one is. Strings are all assumed to be bitstrings whenever the first string doesn’t start with `"0x"`. @@ -260,7 +260,7 @@ python_api_name: qiskit.primitives.BitArray ### get\_bitstrings - + Return a list of bitstrings. **Parameters** @@ -278,7 +278,7 @@ python_api_name: qiskit.primitives.BitArray ### get\_counts - + Return a counts dictionary with bitstring keys. **Parameters** @@ -296,7 +296,7 @@ python_api_name: qiskit.primitives.BitArray ### get\_int\_counts - + Return a counts dictionary, where bitstrings are stored as `int`s. **Parameters** @@ -314,7 +314,7 @@ python_api_name: qiskit.primitives.BitArray ### reshape - + Return a new reshaped bit array. The [`num_shots`](#qiskit.primitives.BitArray.num_shots "qiskit.primitives.BitArray.num_shots") axis is either included or excluded from the reshaping procedure depending on which picture the new shape is compatible with. For example, for a bit array with shape `(20, 5)` and `64` shots, a reshape to `(100,)` would leave the number of shots intact, whereas a reshape to `(200, 32)` would change the number of shots to `32`. @@ -338,7 +338,7 @@ python_api_name: qiskit.primitives.BitArray ### slice\_bits - + Return a bit array sliced along the bit axis of some indices of interest. @@ -366,7 +366,7 @@ python_api_name: qiskit.primitives.BitArray ### slice\_shots - + Return a bit array sliced along the shots axis of some indices of interest. **Parameters** @@ -388,7 +388,7 @@ python_api_name: qiskit.primitives.BitArray ### transpose - + Return a bit array with axes transposed. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.primitives.DataBin.mdx b/docs/api/qiskit/dev/qiskit.primitives.DataBin.mdx index 50f10daa576..38a678e7688 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.DataBin.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.DataBin.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.DataBin # DataBin - + Bases: `ShapedMixin` Namespace for storing data. @@ -51,7 +51,7 @@ python_api_name: qiskit.primitives.DataBin ### items - + Return a view of field names and values **Return type** @@ -61,7 +61,7 @@ python_api_name: qiskit.primitives.DataBin ### keys - + Return a view of field names. **Return type** @@ -71,7 +71,7 @@ python_api_name: qiskit.primitives.DataBin ### values - + Return a view of values. **Return type** diff --git a/docs/api/qiskit/dev/qiskit.primitives.Estimator.mdx b/docs/api/qiskit/dev/qiskit.primitives.Estimator.mdx index 4a06e98ff0e..883b9bf967f 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.Estimator.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.Estimator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.Estimator # Estimator - + Bases: [`BaseEstimatorV1`](qiskit.primitives.BaseEstimatorV1 "qiskit.primitives.base.base_estimator.BaseEstimatorV1")\[[`PrimitiveJob`](qiskit.primitives.PrimitiveJob "qiskit.primitives.primitive_job.PrimitiveJob")\[[`EstimatorResult`](qiskit.primitives.EstimatorResult "qiskit.primitives.base.estimator_result.EstimatorResult")]] Reference implementation of [`BaseEstimator`](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator"). @@ -42,7 +42,7 @@ python_api_name: qiskit.primitives.Estimator ### run - + 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 @@ -86,7 +86,7 @@ python_api_name: qiskit.primitives.Estimator ### set\_options - + Set options values for the estimator. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.primitives.EstimatorResult.mdx b/docs/api/qiskit/dev/qiskit.primitives.EstimatorResult.mdx index 4a6e696a2a7..a8b453d8927 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.EstimatorResult.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.EstimatorResult.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.EstimatorResult # EstimatorResult - + Bases: `_BasePrimitiveResult` Result of Estimator. diff --git a/docs/api/qiskit/dev/qiskit.primitives.PrimitiveJob.mdx b/docs/api/qiskit/dev/qiskit.primitives.PrimitiveJob.mdx index dba5c71d0f3..0b9bc31c8f9 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.PrimitiveJob.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.PrimitiveJob.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.PrimitiveJob # PrimitiveJob - + Bases: [`BasePrimitiveJob`](qiskit.primitives.BasePrimitiveJob "qiskit.primitives.base.base_primitive_job.BasePrimitiveJob")\[`ResultT`, [`JobStatus`](qiskit.providers.JobStatus "qiskit.providers.jobstatus.JobStatus")] Primitive job class for the reference implementations of Primitives. @@ -21,13 +21,13 @@ python_api_name: qiskit.primitives.PrimitiveJob ### cancel - + Attempt to cancel the job. ### cancelled - + Return whether the job has been cancelled. **Return type** @@ -37,7 +37,7 @@ python_api_name: qiskit.primitives.PrimitiveJob ### done - + Return whether the job has successfully run. **Return type** @@ -47,7 +47,7 @@ python_api_name: qiskit.primitives.PrimitiveJob ### in\_final\_state - + Return whether the job is in a final job state such as `DONE` or `ERROR`. **Return type** @@ -57,7 +57,7 @@ python_api_name: qiskit.primitives.PrimitiveJob ### job\_id - + Return a unique id identifying the job. **Return type** @@ -67,7 +67,7 @@ python_api_name: qiskit.primitives.PrimitiveJob ### result - + Return the results of the job. **Return type** @@ -77,7 +77,7 @@ python_api_name: qiskit.primitives.PrimitiveJob ### running - + Return whether the job is actively running. **Return type** @@ -87,7 +87,7 @@ python_api_name: qiskit.primitives.PrimitiveJob ### status - + Return the status of the job. **Return type** diff --git a/docs/api/qiskit/dev/qiskit.primitives.PrimitiveResult.mdx b/docs/api/qiskit/dev/qiskit.primitives.PrimitiveResult.mdx index 218a94459fe..3dd1c42aa13 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.PrimitiveResult.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.PrimitiveResult.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.PrimitiveResult # PrimitiveResult - + Bases: [`Generic`](https://docs.python.org/3/library/typing.html#typing.Generic "(in Python v3.12)")\[`T`] A container for multiple pub results and global metadata. diff --git a/docs/api/qiskit/dev/qiskit.primitives.PubResult.mdx b/docs/api/qiskit/dev/qiskit.primitives.PubResult.mdx index 095d367f8c8..0cb8e824d4d 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.PubResult.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.PubResult.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.PubResult # PubResult - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Result of Primitive Unified Bloc. diff --git a/docs/api/qiskit/dev/qiskit.primitives.Sampler.mdx b/docs/api/qiskit/dev/qiskit.primitives.Sampler.mdx index 2309b5effd8..23fd29921c7 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.Sampler.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.Sampler.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.Sampler # Sampler - + Bases: [`BaseSamplerV1`](qiskit.primitives.BaseSamplerV1 "qiskit.primitives.base.base_sampler.BaseSamplerV1")\[[`PrimitiveJob`](qiskit.primitives.PrimitiveJob "qiskit.primitives.primitive_job.PrimitiveJob")\[[`SamplerResult`](qiskit.primitives.SamplerResult "qiskit.primitives.base.sampler_result.SamplerResult")]] Sampler class. @@ -44,7 +44,7 @@ python_api_name: qiskit.primitives.Sampler ### run - + Run the job of the sampling of bitstrings. **Parameters** @@ -68,7 +68,7 @@ python_api_name: qiskit.primitives.Sampler ### set\_options - + Set options values for the estimator. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.primitives.SamplerPubResult.mdx b/docs/api/qiskit/dev/qiskit.primitives.SamplerPubResult.mdx new file mode 100644 index 00000000000..ea9acef9a83 --- /dev/null +++ b/docs/api/qiskit/dev/qiskit.primitives.SamplerPubResult.mdx @@ -0,0 +1,65 @@ +--- +title: SamplerPubResult +description: API reference for qiskit.primitives.SamplerPubResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.SamplerPubResult +--- + +# SamplerPubResult + + + Bases: [`PubResult`](qiskit.primitives.PubResult "qiskit.primitives.containers.pub_result.PubResult") + + Result of Sampler Pub. + + Initialize a pub result. + + **Parameters** + + * **data** ([*DataBin*](qiskit.primitives.DataBin "qiskit.primitives.DataBin")) – Result data. + * **metadata** ([*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*) – Metadata specific to this pub. Keys are expected to be strings. + + ## Attributes + + ### data + + + Result data for the pub. + + + ### metadata + + + Metadata for the pub. + + + ## Methods + + ### join\_data + + + Join data from many registers into one data container. + + Data is joined along the bits axis. For example, for [`BitArray`](qiskit.primitives.BitArray "qiskit.primitives.BitArray") data, this corresponds to bitstring concatenation. + + **Parameters** + + **names** (*Iterable\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | None*) – Which registers to join. Their order is maintained, for example, given `["alpha", "beta"]`, the data from register `alpha` is placed to the left of the data from register `beta`. When `None` is given, this value is set to the ordered list of register names, which will have been preserved from the input circuit order. + + **Returns** + + Joint data. + + **Raises** + + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If specified names are empty. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If specified name does not exist. + * [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If specified data comes from incompatible types. + + **Return type** + + [BitArray](qiskit.primitives.BitArray "qiskit.primitives.BitArray") | np.ndarray + + + diff --git a/docs/api/qiskit/dev/qiskit.primitives.SamplerResult.mdx b/docs/api/qiskit/dev/qiskit.primitives.SamplerResult.mdx index 8700c64edab..45a15960fec 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.SamplerResult.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.SamplerResult.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.SamplerResult # SamplerResult - + Bases: `_BasePrimitiveResult` Result of Sampler. diff --git a/docs/api/qiskit/dev/qiskit.primitives.StatevectorEstimator.mdx b/docs/api/qiskit/dev/qiskit.primitives.StatevectorEstimator.mdx index a083ebd0501..dd220db59c2 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.StatevectorEstimator.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.StatevectorEstimator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.StatevectorEstimator # StatevectorEstimator - + Bases: [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.base.base_estimator.BaseEstimatorV2") Simple implementation of [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") with full state vector simulation. @@ -101,7 +101,7 @@ python_api_name: qiskit.primitives.StatevectorEstimator ### run - + Estimate expectation values for each provided pub (Primitive Unified Bloc). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.primitives.StatevectorSampler.mdx b/docs/api/qiskit/dev/qiskit.primitives.StatevectorSampler.mdx index e8172e0fb84..a554b8a564a 100644 --- a/docs/api/qiskit/dev/qiskit.primitives.StatevectorSampler.mdx +++ b/docs/api/qiskit/dev/qiskit.primitives.StatevectorSampler.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.StatevectorSampler # StatevectorSampler - + Bases: [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.base.base_sampler.BaseSamplerV2") Simple implementation of [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") using full state vector simulation. @@ -108,7 +108,7 @@ python_api_name: qiskit.primitives.StatevectorSampler ### run - + Run and collect samples from each pub. **Parameters** @@ -122,7 +122,7 @@ python_api_name: qiskit.primitives.StatevectorSampler **Return type** - [PrimitiveJob](qiskit.primitives.PrimitiveJob "qiskit.primitives.PrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[SamplerPubResult]] + [PrimitiveJob](qiskit.primitives.PrimitiveJob "qiskit.primitives.PrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[[SamplerPubResult](qiskit.primitives.SamplerPubResult "qiskit.primitives.SamplerPubResult")]] diff --git a/docs/api/qiskit/dev/qiskit.providers.Backend.mdx b/docs/api/qiskit/dev/qiskit.providers.Backend.mdx index bddc364206d..ee11a3ecce5 100644 --- a/docs/api/qiskit/dev/qiskit.providers.Backend.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.Backend.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.Backend # Backend - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Base common type for all versioned Backend abstract classes. diff --git a/docs/api/qiskit/dev/qiskit.providers.BackendV1.mdx b/docs/api/qiskit/dev/qiskit.providers.BackendV1.mdx index c693aa23d41..5f3e263dba4 100644 --- a/docs/api/qiskit/dev/qiskit.providers.BackendV1.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.BackendV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.BackendV1 # BackendV1 - + 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 @@ -21,7 +21,7 @@ python_api_name: qiskit.providers.BackendV1 ### \_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. @@ -51,7 +51,7 @@ python_api_name: qiskit.providers.BackendV1 In addition to the public abstract methods, subclasses should also implement the following private methods: - + 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. @@ -85,7 +85,7 @@ python_api_name: qiskit.providers.BackendV1 ### configuration - + Return the backend configuration. **Returns** @@ -99,7 +99,7 @@ python_api_name: qiskit.providers.BackendV1 ### name - + Return the backend name. **Returns** @@ -113,7 +113,7 @@ python_api_name: qiskit.providers.BackendV1 ### properties - + Return the backend properties. **Returns** @@ -127,7 +127,7 @@ python_api_name: qiskit.providers.BackendV1 ### provider - + Return the backend Provider. **Returns** @@ -141,7 +141,7 @@ python_api_name: qiskit.providers.BackendV1 ### run - + 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. @@ -162,7 +162,7 @@ python_api_name: qiskit.providers.BackendV1 ### set\_options - + 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. @@ -178,7 +178,7 @@ python_api_name: qiskit.providers.BackendV1 ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.BackendV2.mdx b/docs/api/qiskit/dev/qiskit.providers.BackendV2.mdx index 487186702e4..464aadd85db 100644 --- a/docs/api/qiskit/dev/qiskit.providers.BackendV2.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.BackendV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.BackendV2 # BackendV2 - + 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 @@ -25,7 +25,7 @@ python_api_name: qiskit.providers.BackendV2 ### \_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. @@ -214,7 +214,7 @@ python_api_name: qiskit.providers.BackendV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -234,7 +234,7 @@ python_api_name: qiskit.providers.BackendV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -260,7 +260,7 @@ python_api_name: qiskit.providers.BackendV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -280,7 +280,7 @@ python_api_name: qiskit.providers.BackendV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -300,7 +300,7 @@ python_api_name: qiskit.providers.BackendV2 ### qubit\_properties - + 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. @@ -324,7 +324,7 @@ python_api_name: qiskit.providers.BackendV2 ### run - + 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. @@ -345,7 +345,7 @@ python_api_name: qiskit.providers.BackendV2 ### set\_options - + 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. diff --git a/docs/api/qiskit/dev/qiskit.providers.BackendV2Converter.mdx b/docs/api/qiskit/dev/qiskit.providers.BackendV2Converter.mdx index 72abbdb8372..1a57540dcac 100644 --- a/docs/api/qiskit/dev/qiskit.providers.BackendV2Converter.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.BackendV2Converter.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.BackendV2Converter # BackendV2Converter - + 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. @@ -167,7 +167,7 @@ python_api_name: qiskit.providers.BackendV2Converter ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -187,7 +187,7 @@ python_api_name: qiskit.providers.BackendV2Converter ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -213,7 +213,7 @@ python_api_name: qiskit.providers.BackendV2Converter ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -233,7 +233,7 @@ python_api_name: qiskit.providers.BackendV2Converter ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -253,7 +253,7 @@ python_api_name: qiskit.providers.BackendV2Converter ### qubit\_properties - + 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. @@ -277,7 +277,7 @@ python_api_name: qiskit.providers.BackendV2Converter ### run - + 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. @@ -298,7 +298,7 @@ python_api_name: qiskit.providers.BackendV2Converter ### set\_options - + 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. diff --git a/docs/api/qiskit/dev/qiskit.providers.Job.mdx b/docs/api/qiskit/dev/qiskit.providers.Job.mdx index f1c1b04ffcf..b4a917e1b32 100644 --- a/docs/api/qiskit/dev/qiskit.providers.Job.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.Job.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.Job # Job - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Base common type for all versioned Job abstract classes. diff --git a/docs/api/qiskit/dev/qiskit.providers.JobStatus.mdx b/docs/api/qiskit/dev/qiskit.providers.JobStatus.mdx index 31bbdeef588..4c6260621ee 100644 --- a/docs/api/qiskit/dev/qiskit.providers.JobStatus.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.JobStatus.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.JobStatus # JobStatus - + Bases: [`Enum`](https://docs.python.org/3/library/enum.html#enum.Enum "(in Python v3.12)") Class for job status enumerated type. diff --git a/docs/api/qiskit/dev/qiskit.providers.JobV1.mdx b/docs/api/qiskit/dev/qiskit.providers.JobV1.mdx index 86b5640f885..6721923cf06 100644 --- a/docs/api/qiskit/dev/qiskit.providers.JobV1.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.JobV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.JobV1 # JobV1 - + 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 @@ -33,7 +33,7 @@ python_api_name: qiskit.providers.JobV1 ### backend - + Return the backend where this job was executed. **Return type** @@ -43,13 +43,13 @@ python_api_name: qiskit.providers.JobV1 ### cancel - + Attempt to cancel the job. ### cancelled - + Return whether the job has been cancelled. **Return type** @@ -59,7 +59,7 @@ python_api_name: qiskit.providers.JobV1 ### done - + Return whether the job has successfully run. **Return type** @@ -69,7 +69,7 @@ python_api_name: qiskit.providers.JobV1 ### in\_final\_state - + Return whether the job is in a final job state such as `DONE` or `ERROR`. **Return type** @@ -79,7 +79,7 @@ python_api_name: qiskit.providers.JobV1 ### job\_id - + Return a unique id identifying the job. **Return type** @@ -89,7 +89,7 @@ python_api_name: qiskit.providers.JobV1 ### result - + Return the results of the job. **Return type** @@ -99,7 +99,7 @@ python_api_name: qiskit.providers.JobV1 ### running - + Return whether the job is actively running. **Return type** @@ -109,7 +109,7 @@ python_api_name: qiskit.providers.JobV1 ### status - + Return the status of the job, among the values of `JobStatus`. **Return type** @@ -119,13 +119,13 @@ python_api_name: qiskit.providers.JobV1 ### submit - + Submit the job to the backend for execution. ### wait\_for\_final\_state - + Poll the job status until it progresses to a final state such as `DONE` or `ERROR`. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.providers.Options.mdx b/docs/api/qiskit/dev/qiskit.providers.Options.mdx index 7ada83881ff..9dc6ae32977 100644 --- a/docs/api/qiskit/dev/qiskit.providers.Options.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.Options.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.Options # Options - + Bases: [`Mapping`](https://docs.python.org/3/library/collections.abc.html#collections.abc.Mapping "(in Python v3.12)") Base options object @@ -75,7 +75,7 @@ python_api_name: qiskit.providers.Options ### set\_validator - + 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: @@ -100,7 +100,7 @@ python_api_name: qiskit.providers.Options ### update\_options - + Update options with kwargs diff --git a/docs/api/qiskit/dev/qiskit.providers.Provider.mdx b/docs/api/qiskit/dev/qiskit.providers.Provider.mdx index 56d5637adb0..62144c1287b 100644 --- a/docs/api/qiskit/dev/qiskit.providers.Provider.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.Provider.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.Provider # Provider - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Base common type for all versioned Provider abstract classes. diff --git a/docs/api/qiskit/dev/qiskit.providers.ProviderV1.mdx b/docs/api/qiskit/dev/qiskit.providers.ProviderV1.mdx index d88e38379c9..f5a07561cbb 100644 --- a/docs/api/qiskit/dev/qiskit.providers.ProviderV1.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.ProviderV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.ProviderV1 # ProviderV1 - + 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. @@ -27,7 +27,7 @@ python_api_name: qiskit.providers.ProviderV1 ### backends - + Return a list of backends matching the specified filtering. **Parameters** @@ -48,7 +48,7 @@ python_api_name: qiskit.providers.ProviderV1 ### get\_backend - + Return a single backend matching the specified filtering. diff --git a/docs/api/qiskit/dev/qiskit.providers.QubitProperties.mdx b/docs/api/qiskit/dev/qiskit.providers.QubitProperties.mdx index 5900557b324..b85775e7e78 100644 --- a/docs/api/qiskit/dev/qiskit.providers.QubitProperties.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.QubitProperties.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.QubitProperties # QubitProperties - + 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. diff --git a/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicProvider.mdx b/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicProvider.mdx index 2f2297cf923..d27cbfe1d42 100644 --- a/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicProvider.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicProvider.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProvider # BasicProvider - + Bases: [`ProviderV1`](qiskit.providers.ProviderV1 "qiskit.providers.provider.ProviderV1") Provider for test simulators. @@ -27,7 +27,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProvider ### backends - + Return a list of backends matching the specified filtering. **Parameters** @@ -48,7 +48,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProvider ### get\_backend - + Return a single backend matching the specified filtering. diff --git a/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicProviderError.mdx b/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicProviderError.mdx index eb2a3d19d40..7b1af50a9d1 100644 --- a/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicProviderError.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicProviderError.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderError # qiskit.providers.basic\_provider.BasicProviderError - + Base class for errors raised by the Basic Provider. Set the error message. diff --git a/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicProviderJob.mdx b/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicProviderJob.mdx index ce5c5f20186..81e28a3a641 100644 --- a/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicProviderJob.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicProviderJob.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob # BasicProviderJob - + Bases: [`JobV1`](qiskit.providers.JobV1 "qiskit.providers.job.JobV1") BasicProviderJob class. @@ -31,19 +31,19 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### backend - + Return the instance of the backend used for this job. ### cancel - + Attempt to cancel the job. ### cancelled - + Return whether the job has been cancelled. **Return type** @@ -53,7 +53,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### done - + Return whether the job has successfully run. **Return type** @@ -63,7 +63,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### in\_final\_state - + Return whether the job is in a final job state such as `DONE` or `ERROR`. **Return type** @@ -73,7 +73,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### job\_id - + Return a unique id identifying the job. **Return type** @@ -83,7 +83,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### result - + Get job result . **Returns** @@ -97,7 +97,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### running - + Return whether the job is actively running. **Return type** @@ -107,7 +107,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### status - + Gets the status of the job by querying the Python’s future **Returns** @@ -121,7 +121,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### submit - + Submit the job to the backend for execution. **Raises** @@ -131,7 +131,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### wait\_for\_final\_state - + Poll the job status until it progresses to a final state such as `DONE` or `ERROR`. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicSimulator.mdx b/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicSimulator.mdx index 51459aa009b..b21859a8989 100644 --- a/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicSimulator.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.basic_provider.BasicSimulator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator # BasicSimulator - + Bases: [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.backend.BackendV2") Python implementation of a basic (non-efficient) quantum simulator. @@ -175,7 +175,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -195,7 +195,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### configuration - + Return the simulator backend configuration. **Returns** @@ -209,7 +209,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -235,7 +235,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -255,7 +255,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -275,7 +275,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### qubit\_properties - + 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. @@ -299,7 +299,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### run - + Run on the backend. **Parameters** @@ -334,7 +334,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### run\_experiment - + Run an experiment (circuit) and return a single experiment result. **Parameters** @@ -372,7 +372,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### set\_options - + 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. diff --git a/docs/api/qiskit/dev/qiskit.providers.convert_to_target.mdx b/docs/api/qiskit/dev/qiskit.providers.convert_to_target.mdx index 0316a65f4de..e0aa4a39958 100644 --- a/docs/api/qiskit/dev/qiskit.providers.convert_to_target.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.convert_to_target.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.providers.convert_to_target # qiskit.providers.convert\_to\_target - + Decode transpiler target from backend data set. This function generates `` Target` `` instance from intermediate legacy objects such as [`BackendProperties`](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") and [`PulseDefaults`](qiskit.providers.models.PulseDefaults "qiskit.providers.models.PulseDefaults"). These objects are usually components of the legacy [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") model. diff --git a/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake127QPulseV1.mdx b/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake127QPulseV1.mdx index e4d530eb9ed..bebec7b916c 100644 --- a/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake127QPulseV1.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake127QPulseV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.Fake127QPulseV1 # Fake127QPulseV1 - + Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") A fake **pulse** backend with the following characteristics: @@ -68,7 +68,7 @@ python_api_name: qiskit.providers.fake_provider.Fake127QPulseV1 ### configuration - + Return the backend configuration. **Returns** @@ -82,13 +82,13 @@ python_api_name: qiskit.providers.fake_provider.Fake127QPulseV1 ### defaults - + Returns a snapshot of device defaults ### name - + Return the backend name. **Returns** @@ -102,13 +102,13 @@ python_api_name: qiskit.providers.fake_provider.Fake127QPulseV1 ### properties - + Returns a snapshot of device properties ### provider - + Return the backend Provider. **Returns** @@ -122,13 +122,13 @@ python_api_name: qiskit.providers.fake_provider.Fake127QPulseV1 ### run - + Main job in simulator ### set\_options - + 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. @@ -144,7 +144,7 @@ python_api_name: qiskit.providers.fake_provider.Fake127QPulseV1 ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake1Q.mdx b/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake1Q.mdx index 07f87d72b47..cbbaac852fe 100644 --- a/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake1Q.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake1Q.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.Fake1Q # Fake1Q - + Bases: [`FakeBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.fake_backend.FakeBackend") A fake 1Q backend. @@ -33,7 +33,7 @@ python_api_name: qiskit.providers.fake_provider.Fake1Q ### configuration - + Return the backend configuration. **Returns** @@ -47,7 +47,7 @@ python_api_name: qiskit.providers.fake_provider.Fake1Q ### name - + Return the backend name. **Returns** @@ -61,13 +61,13 @@ python_api_name: qiskit.providers.fake_provider.Fake1Q ### properties - + Return backend properties ### provider - + Return the backend Provider. **Returns** @@ -81,13 +81,13 @@ python_api_name: qiskit.providers.fake_provider.Fake1Q ### run - + Main job in simulator ### set\_options - + 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. @@ -103,7 +103,7 @@ python_api_name: qiskit.providers.fake_provider.Fake1Q ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake20QV1.mdx b/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake20QV1.mdx index 0498c840237..bd89845d2ad 100644 --- a/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake20QV1.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake20QV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.Fake20QV1 # Fake20QV1 - + Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") A fake backend with the following characteristics: @@ -70,7 +70,7 @@ python_api_name: qiskit.providers.fake_provider.Fake20QV1 ### configuration - + Return the backend configuration. **Returns** @@ -84,7 +84,7 @@ python_api_name: qiskit.providers.fake_provider.Fake20QV1 ### name - + Return the backend name. **Returns** @@ -98,13 +98,13 @@ python_api_name: qiskit.providers.fake_provider.Fake20QV1 ### properties - + Returns a snapshot of device properties ### provider - + Return the backend Provider. **Returns** @@ -118,13 +118,13 @@ python_api_name: qiskit.providers.fake_provider.Fake20QV1 ### run - + Main job in simulator ### set\_options - + 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. @@ -140,7 +140,7 @@ python_api_name: qiskit.providers.fake_provider.Fake20QV1 ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake27QPulseV1.mdx b/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake27QPulseV1.mdx index f898402fe21..b99937c2d6a 100644 --- a/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake27QPulseV1.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake27QPulseV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.Fake27QPulseV1 # Fake27QPulseV1 - + Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") A fake **pulse** backend with the following characteristics: @@ -80,7 +80,7 @@ python_api_name: qiskit.providers.fake_provider.Fake27QPulseV1 ### configuration - + Return the backend configuration. **Returns** @@ -94,13 +94,13 @@ python_api_name: qiskit.providers.fake_provider.Fake27QPulseV1 ### defaults - + Returns a snapshot of device defaults ### name - + Return the backend name. **Returns** @@ -114,13 +114,13 @@ python_api_name: qiskit.providers.fake_provider.Fake27QPulseV1 ### properties - + Returns a snapshot of device properties ### provider - + Return the backend Provider. **Returns** @@ -134,13 +134,13 @@ python_api_name: qiskit.providers.fake_provider.Fake27QPulseV1 ### run - + Main job in simulator ### set\_options - + 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. @@ -156,7 +156,7 @@ python_api_name: qiskit.providers.fake_provider.Fake27QPulseV1 ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake5QV1.mdx b/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake5QV1.mdx index 58d484bcee6..9b6d5669377 100644 --- a/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake5QV1.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake5QV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.Fake5QV1 # Fake5QV1 - + Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") A fake backend with the following characteristics: @@ -68,7 +68,7 @@ python_api_name: qiskit.providers.fake_provider.Fake5QV1 ### configuration - + Return the backend configuration. **Returns** @@ -82,7 +82,7 @@ python_api_name: qiskit.providers.fake_provider.Fake5QV1 ### name - + Return the backend name. **Returns** @@ -96,13 +96,13 @@ python_api_name: qiskit.providers.fake_provider.Fake5QV1 ### properties - + Returns a snapshot of device properties ### provider - + Return the backend Provider. **Returns** @@ -116,13 +116,13 @@ python_api_name: qiskit.providers.fake_provider.Fake5QV1 ### run - + Main job in simulator ### set\_options - + 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. @@ -138,7 +138,7 @@ python_api_name: qiskit.providers.fake_provider.Fake5QV1 ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake7QPulseV1.mdx b/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake7QPulseV1.mdx index 2aa3bde2598..102265625a8 100644 --- a/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake7QPulseV1.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.fake_provider.Fake7QPulseV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.Fake7QPulseV1 # Fake7QPulseV1 - + Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") A fake **pulse** backend with the following characteristics: @@ -74,7 +74,7 @@ python_api_name: qiskit.providers.fake_provider.Fake7QPulseV1 ### configuration - + Return the backend configuration. **Returns** @@ -88,13 +88,13 @@ python_api_name: qiskit.providers.fake_provider.Fake7QPulseV1 ### defaults - + Returns a snapshot of device defaults ### name - + Return the backend name. **Returns** @@ -108,13 +108,13 @@ python_api_name: qiskit.providers.fake_provider.Fake7QPulseV1 ### properties - + Returns a snapshot of device properties ### provider - + Return the backend Provider. **Returns** @@ -128,13 +128,13 @@ python_api_name: qiskit.providers.fake_provider.Fake7QPulseV1 ### run - + Main job in simulator ### set\_options - + 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. @@ -150,7 +150,7 @@ python_api_name: qiskit.providers.fake_provider.Fake7QPulseV1 ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.fake_provider.FakeOpenPulse2Q.mdx b/docs/api/qiskit/dev/qiskit.providers.fake_provider.FakeOpenPulse2Q.mdx index 80b0f4bb9ff..b45f62f1fc5 100644 --- a/docs/api/qiskit/dev/qiskit.providers.fake_provider.FakeOpenPulse2Q.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.fake_provider.FakeOpenPulse2Q.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse2Q # FakeOpenPulse2Q - + 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. @@ -38,7 +38,7 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse2Q ### configuration - + Return the backend configuration. **Returns** @@ -52,13 +52,13 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse2Q ### defaults - + Return the default pulse-related settings provided by the backend (such as gate to Schedule mappings). ### name - + Return the backend name. **Returns** @@ -72,13 +72,13 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse2Q ### properties - + Return the measured characteristics of the backend. ### provider - + Return the backend Provider. **Returns** @@ -92,13 +92,13 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse2Q ### run - + Main job in simulator ### set\_options - + 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. @@ -114,7 +114,7 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse2Q ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.fake_provider.FakeOpenPulse3Q.mdx b/docs/api/qiskit/dev/qiskit.providers.fake_provider.FakeOpenPulse3Q.mdx index 4b6affb474b..88cb30e82b6 100644 --- a/docs/api/qiskit/dev/qiskit.providers.fake_provider.FakeOpenPulse3Q.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.fake_provider.FakeOpenPulse3Q.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse3Q # FakeOpenPulse3Q - + Bases: [`FakeBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.fake_backend.FakeBackend") Trivial extension of the FakeOpenPulse2Q. @@ -38,7 +38,7 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse3Q ### configuration - + Return the backend configuration. **Returns** @@ -52,11 +52,11 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse3Q ### defaults - + ### name - + Return the backend name. **Returns** @@ -70,13 +70,13 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse3Q ### properties - + Return backend properties ### provider - + Return the backend Provider. **Returns** @@ -90,13 +90,13 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse3Q ### run - + Main job in simulator ### set\_options - + 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. @@ -112,7 +112,7 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse3Q ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.fake_provider.GenericBackendV2.mdx b/docs/api/qiskit/dev/qiskit.providers.fake_provider.GenericBackendV2.mdx index c7d63349723..b0135b09def 100644 --- a/docs/api/qiskit/dev/qiskit.providers.fake_provider.GenericBackendV2.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.fake_provider.GenericBackendV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 # GenericBackendV2 - + 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. @@ -180,7 +180,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -200,7 +200,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -226,7 +226,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -246,7 +246,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -266,7 +266,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 ### qubit\_properties - + 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. @@ -290,7 +290,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 ### run - + 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. @@ -319,7 +319,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 ### set\_options - + 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. diff --git a/docs/api/qiskit/dev/qiskit.providers.models.BackendConfiguration.mdx b/docs/api/qiskit/dev/qiskit.providers.models.BackendConfiguration.mdx index 717b7b82657..64b3f5891c9 100644 --- a/docs/api/qiskit/dev/qiskit.providers.models.BackendConfiguration.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.models.BackendConfiguration.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.BackendConfiguration # BackendConfiguration - + Bases: [`QasmBackendConfiguration`](qiskit.providers.models.QasmBackendConfiguration "qiskit.providers.models.backendconfiguration.QasmBackendConfiguration") Backwards compat shim representing an abstract backend configuration. @@ -99,7 +99,7 @@ python_api_name: qiskit.providers.models.BackendConfiguration ### from\_dict - + Create a new GateConfig object from a dictionary. **Parameters** @@ -117,7 +117,7 @@ python_api_name: qiskit.providers.models.BackendConfiguration ### to\_dict - + Return a dictionary format representation of the GateConfig. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.models.BackendProperties.mdx b/docs/api/qiskit/dev/qiskit.providers.models.BackendProperties.mdx index b9ee1f348cc..d2e8451a32b 100644 --- a/docs/api/qiskit/dev/qiskit.providers.models.BackendProperties.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.models.BackendProperties.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.BackendProperties # BackendProperties - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing backend properties @@ -31,19 +31,19 @@ python_api_name: qiskit.providers.models.BackendProperties ### faulty\_gates - + Return a list of faulty gates. ### faulty\_qubits - + Return a list of faulty qubits. ### frequency - + Return the frequency of the given qubit. **Parameters** @@ -61,7 +61,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### from\_dict - + Create a new BackendProperties object from a dictionary. **Parameters** @@ -79,7 +79,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### gate\_error - + Return gate error estimates from backend properties. **Parameters** @@ -98,7 +98,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### gate\_length - + Return the duration of the gate in units of seconds. **Parameters** @@ -117,7 +117,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### gate\_property - + Return the property of the given gate. **Parameters** @@ -141,7 +141,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### is\_gate\_operational - + Return the operational status of the given gate. **Parameters** @@ -160,7 +160,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### is\_qubit\_operational - + Return the operational status of the given qubit. **Parameters** @@ -178,7 +178,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### qubit\_property - + Return the property of the given qubit. **Parameters** @@ -201,7 +201,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### readout\_error - + Return the readout error of the given qubit. **Parameters** @@ -219,7 +219,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### readout\_length - + Return the readout length \[sec] of the given qubit. **Parameters** @@ -237,7 +237,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### t1 - + Return the T1 time of the given qubit. **Parameters** @@ -255,7 +255,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### t2 - + Return the T2 time of the given qubit. **Parameters** @@ -273,7 +273,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### to\_dict - + Return a dictionary format representation of the BackendProperties. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.models.BackendStatus.mdx b/docs/api/qiskit/dev/qiskit.providers.models.BackendStatus.mdx index 253da30bb9d..56429efb3f7 100644 --- a/docs/api/qiskit/dev/qiskit.providers.models.BackendStatus.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.models.BackendStatus.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.BackendStatus # BackendStatus - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing Backend Status. @@ -31,7 +31,7 @@ python_api_name: qiskit.providers.models.BackendStatus ### from\_dict - + Create a new BackendStatus object from a dictionary. **Parameters** @@ -49,7 +49,7 @@ python_api_name: qiskit.providers.models.BackendStatus ### to\_dict - + Return a dictionary format representation of the BackendStatus. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.models.Command.mdx b/docs/api/qiskit/dev/qiskit.providers.models.Command.mdx index 0fc6654e34b..7220c2ca9b9 100644 --- a/docs/api/qiskit/dev/qiskit.providers.models.Command.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.models.Command.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.Command # Command - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing a Command. @@ -32,7 +32,7 @@ python_api_name: qiskit.providers.models.Command ### from\_dict - + Create a new Command object from a dictionary. **Parameters** @@ -50,7 +50,7 @@ python_api_name: qiskit.providers.models.Command ### to\_dict - + Return a dictionary format representation of the Command. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.models.GateConfig.mdx b/docs/api/qiskit/dev/qiskit.providers.models.GateConfig.mdx index a973aaaa4dd..f62bb319ddf 100644 --- a/docs/api/qiskit/dev/qiskit.providers.models.GateConfig.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.models.GateConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.GateConfig # GateConfig - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing a Gate Configuration @@ -47,7 +47,7 @@ python_api_name: qiskit.providers.models.GateConfig ### from\_dict - + Create a new GateConfig object from a dictionary. **Parameters** @@ -65,7 +65,7 @@ python_api_name: qiskit.providers.models.GateConfig ### to\_dict - + Return a dictionary format representation of the GateConfig. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.models.GateProperties.mdx b/docs/api/qiskit/dev/qiskit.providers.models.GateProperties.mdx index 66b83b0e256..73580f1303c 100644 --- a/docs/api/qiskit/dev/qiskit.providers.models.GateProperties.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.models.GateProperties.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.GateProperties # GateProperties - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing a gate’s properties @@ -44,7 +44,7 @@ python_api_name: qiskit.providers.models.GateProperties ### from\_dict - + Create a new Gate object from a dictionary. **Parameters** @@ -62,7 +62,7 @@ python_api_name: qiskit.providers.models.GateProperties ### to\_dict - + Return a dictionary format representation of the BackendStatus. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.models.JobStatus.mdx b/docs/api/qiskit/dev/qiskit.providers.models.JobStatus.mdx index 67ae07361ac..e5214df9166 100644 --- a/docs/api/qiskit/dev/qiskit.providers.models.JobStatus.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.models.JobStatus.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.JobStatus # JobStatus - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Model for JobStatus. @@ -47,7 +47,7 @@ python_api_name: qiskit.providers.models.JobStatus ### from\_dict - + Create a new JobStatus object from a dictionary. **Parameters** @@ -65,7 +65,7 @@ python_api_name: qiskit.providers.models.JobStatus ### to\_dict - + Return a dictionary format representation of the JobStatus. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.models.Nduv.mdx b/docs/api/qiskit/dev/qiskit.providers.models.Nduv.mdx index 5f1284ddd5e..196f0caf437 100644 --- a/docs/api/qiskit/dev/qiskit.providers.models.Nduv.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.models.Nduv.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.Nduv # Nduv - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing name-date-unit-value @@ -50,7 +50,7 @@ python_api_name: qiskit.providers.models.Nduv ### from\_dict - + Create a new Nduv object from a dictionary. **Parameters** @@ -68,7 +68,7 @@ python_api_name: qiskit.providers.models.Nduv ### to\_dict - + Return a dictionary format representation of the object. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.models.PulseBackendConfiguration.mdx b/docs/api/qiskit/dev/qiskit.providers.models.PulseBackendConfiguration.mdx index 3514a5123b9..6fe770da1f2 100644 --- a/docs/api/qiskit/dev/qiskit.providers.models.PulseBackendConfiguration.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.models.PulseBackendConfiguration.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration # PulseBackendConfiguration - + 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. @@ -83,7 +83,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### acquire - + Return the acquisition channel for the given qubit. **Raises** @@ -101,7 +101,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### control - + Return the secondary drive channel for the given qubit – typically utilized for controlling multiqubit interactions. This channel is derived from other channels. **Parameters** @@ -123,7 +123,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### describe - + 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 @@ -159,7 +159,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### drive - + Return the drive channel for the given qubit. **Raises** @@ -177,7 +177,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### from\_dict - + Create a new GateConfig object from a dictionary. **Parameters** @@ -195,7 +195,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### get\_channel\_qubits - + Return a list of indices for qubits which are operated on directly by the given `channel`. **Raises** @@ -213,7 +213,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### get\_qubit\_channels - + Return a list of channels which operate on the given `qubit`. **Raises** @@ -231,7 +231,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### measure - + Return the measure stimulus channel for the given qubit. **Raises** @@ -249,7 +249,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### to\_dict - + Return a dictionary format representation of the GateConfig. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.models.PulseDefaults.mdx b/docs/api/qiskit/dev/qiskit.providers.models.PulseDefaults.mdx index deb6583c28a..57a497d83b9 100644 --- a/docs/api/qiskit/dev/qiskit.providers.models.PulseDefaults.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.models.PulseDefaults.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.PulseDefaults # PulseDefaults - + 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. @@ -33,7 +33,7 @@ python_api_name: qiskit.providers.models.PulseDefaults ### from\_dict - + Create a new PulseDefaults object from a dictionary. **Parameters** @@ -51,7 +51,7 @@ python_api_name: qiskit.providers.models.PulseDefaults ### 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/dev/qiskit.providers.models.QasmBackendConfiguration.mdx b/docs/api/qiskit/dev/qiskit.providers.models.QasmBackendConfiguration.mdx index 09c8ba803c5..0af791e7b83 100644 --- a/docs/api/qiskit/dev/qiskit.providers.models.QasmBackendConfiguration.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.models.QasmBackendConfiguration.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.QasmBackendConfiguration # QasmBackendConfiguration - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing an OpenQASM 2.0 Backend Configuration. @@ -165,7 +165,7 @@ python_api_name: qiskit.providers.models.QasmBackendConfiguration ### from\_dict - + Create a new GateConfig object from a dictionary. **Parameters** @@ -183,7 +183,7 @@ python_api_name: qiskit.providers.models.QasmBackendConfiguration ### to\_dict - + Return a dictionary format representation of the GateConfig. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.providers.models.UchannelLO.mdx b/docs/api/qiskit/dev/qiskit.providers.models.UchannelLO.mdx index 58878f8dd01..b507ed5e074 100644 --- a/docs/api/qiskit/dev/qiskit.providers.models.UchannelLO.mdx +++ b/docs/api/qiskit/dev/qiskit.providers.models.UchannelLO.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.UchannelLO # UchannelLO - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing a U Channel LO @@ -40,7 +40,7 @@ python_api_name: qiskit.providers.models.UchannelLO ### from\_dict - + Create a new UchannelLO object from a dictionary. **Parameters** @@ -58,7 +58,7 @@ python_api_name: qiskit.providers.models.UchannelLO ### to\_dict - + Return a dictionary format representation of the UChannelLO. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.pulse.InstructionScheduleMap.mdx b/docs/api/qiskit/dev/qiskit.pulse.InstructionScheduleMap.mdx index 319e1a14886..eb1f59fe4b5 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.InstructionScheduleMap.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.InstructionScheduleMap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap # InstructionScheduleMap - + 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: @@ -41,7 +41,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### add - + Add a new known instruction for the given qubits and its mapping to a pulse schedule. **Parameters** @@ -58,7 +58,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### assert\_has - + Error if the given instruction is not defined. **Parameters** @@ -73,7 +73,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### get - + 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. @@ -96,7 +96,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### get\_parameters - + Return the list of parameters taken by the given instruction on the given qubits. **Parameters** @@ -115,7 +115,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### has - + Is the instruction defined for the given qubits? **Parameters** @@ -134,7 +134,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### has\_custom\_gate - + Return `True` if the map has user provided instruction. **Return type** @@ -144,7 +144,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### pop - + Remove and return the defined schedule for the given instruction on the given qubits. **Parameters** @@ -165,7 +165,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### qubit\_instructions - + Return a list of the instruction names that are defined by the backend for the given qubit or qubits. **Parameters** @@ -185,7 +185,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### qubits\_with\_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** @@ -207,7 +207,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### remove - + Remove the given instruction from the listing of instructions defined in self. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.pulse.Schedule.mdx b/docs/api/qiskit/dev/qiskit.pulse.Schedule.mdx index 02d17e02e1f..b804a425c62 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.Schedule.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.Schedule.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.Schedule # Schedule - + 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. @@ -148,7 +148,7 @@ python_api_name: qiskit.pulse.Schedule ### append - + Return a new schedule with `schedule` inserted at the maximum time over all channels shared between `self` and `schedule`. $$ @@ -169,7 +169,7 @@ $$ ### assign\_parameters - + Assign the parameters in this schedule according to the input. **Parameters** @@ -190,7 +190,7 @@ $$ ### ch\_duration - + Return the time of the end of the last instruction over the supplied channels. **Parameters** @@ -204,7 +204,7 @@ $$ ### ch\_start\_time - + Return the time of the start of the first instruction over the supplied channels. **Parameters** @@ -218,7 +218,7 @@ $$ ### ch\_stop\_time - + Return maximum start time over supplied channels. **Parameters** @@ -232,7 +232,7 @@ $$ ### draw - + Plot the schedule. **Parameters** @@ -278,7 +278,7 @@ $$ ### exclude - + 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 @@ -301,7 +301,7 @@ $$ ### filter - + 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. @@ -322,7 +322,7 @@ $$ ### get\_parameters - + 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. @@ -342,7 +342,7 @@ $$ ### initialize\_from - + Create new schedule object with metadata of another schedule object. **Parameters** @@ -365,7 +365,7 @@ $$ ### insert - + Return a new schedule with `schedule` inserted into `self` at `start_time`. **Parameters** @@ -382,7 +382,7 @@ $$ ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -392,7 +392,7 @@ $$ ### replace - + Return a `Schedule` with the `old` instruction replaced with a `new` instruction. The replacement matching is based on an instruction equality check. @@ -451,7 +451,7 @@ $$ ### shift - + Return a schedule shifted forward by `time`. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.pulse.ScheduleBlock.mdx b/docs/api/qiskit/dev/qiskit.pulse.ScheduleBlock.mdx index 7c49a019272..ea960da6a8b 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.ScheduleBlock.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.ScheduleBlock.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.ScheduleBlock # ScheduleBlock - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Time-ordered sequence of instructions with alignment context. @@ -200,7 +200,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### append - + 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** @@ -224,7 +224,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### assign\_parameters - + Assign the parameters in this schedule according to the input. **Parameters** @@ -249,7 +249,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### assign\_references - + 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: @@ -307,7 +307,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### ch\_duration - + Return the time of the end of the last instruction over the supplied channels. **Parameters** @@ -321,7 +321,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### draw - + Plot the schedule. **Parameters** @@ -367,7 +367,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### exclude - + 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 @@ -392,7 +392,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### filter - + 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`. @@ -415,7 +415,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### get\_parameters - + 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, @@ -453,7 +453,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### initialize\_from - + Create new schedule object with metadata of another schedule object. **Parameters** @@ -476,7 +476,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -486,7 +486,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### is\_referenced - + Return True iff the current schedule block contains reference to subroutine. **Return type** @@ -496,7 +496,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### is\_schedulable - + Return `True` if all durations are assigned. **Return type** @@ -506,7 +506,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### replace - + Return a `ScheduleBlock` with the `old` component replaced with a `new` component. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.pulse.channels.AcquireChannel.mdx b/docs/api/qiskit/dev/qiskit.pulse.channels.AcquireChannel.mdx index 33c769b3d1a..1811e16c48e 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.channels.AcquireChannel.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.channels.AcquireChannel.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.channels.AcquireChannel # AcquireChannel - + Bases: [`Channel`](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") Acquire channels are used to collect data. @@ -49,7 +49,7 @@ python_api_name: qiskit.pulse.channels.AcquireChannel ### is\_parameterized - + Return True iff the channel is parameterized. **Return type** diff --git a/docs/api/qiskit/dev/qiskit.pulse.channels.ControlChannel.mdx b/docs/api/qiskit/dev/qiskit.pulse.channels.ControlChannel.mdx index 0e8efd40652..ca47925361b 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.channels.ControlChannel.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.channels.ControlChannel.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.channels.ControlChannel # ControlChannel - + 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. @@ -49,7 +49,7 @@ python_api_name: qiskit.pulse.channels.ControlChannel ### is\_parameterized - + Return True iff the channel is parameterized. **Return type** diff --git a/docs/api/qiskit/dev/qiskit.pulse.channels.DriveChannel.mdx b/docs/api/qiskit/dev/qiskit.pulse.channels.DriveChannel.mdx index 5eeb1c3a0eb..298d98ce2aa 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.channels.DriveChannel.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.channels.DriveChannel.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.channels.DriveChannel # DriveChannel - + Bases: `PulseChannel` Drive channels transmit signals to qubits which enact gate operations. @@ -49,7 +49,7 @@ python_api_name: qiskit.pulse.channels.DriveChannel ### is\_parameterized - + Return True iff the channel is parameterized. **Return type** diff --git a/docs/api/qiskit/dev/qiskit.pulse.channels.MeasureChannel.mdx b/docs/api/qiskit/dev/qiskit.pulse.channels.MeasureChannel.mdx index 99b70286bf5..79c723c1e75 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.channels.MeasureChannel.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.channels.MeasureChannel.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.channels.MeasureChannel # MeasureChannel - + Bases: `PulseChannel` Measure channels transmit measurement stimulus pulses for readout. @@ -49,7 +49,7 @@ python_api_name: qiskit.pulse.channels.MeasureChannel ### is\_parameterized - + Return True iff the channel is parameterized. **Return type** diff --git a/docs/api/qiskit/dev/qiskit.pulse.channels.MemorySlot.mdx b/docs/api/qiskit/dev/qiskit.pulse.channels.MemorySlot.mdx index e4a2d09f114..b65c3d72671 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.channels.MemorySlot.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.channels.MemorySlot.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.channels.MemorySlot # MemorySlot - + Bases: `ClassicalIOChannel` Memory slot channels represent classical memory storage. @@ -49,7 +49,7 @@ python_api_name: qiskit.pulse.channels.MemorySlot ### is\_parameterized - + Return True iff the channel is parameterized. **Return type** diff --git a/docs/api/qiskit/dev/qiskit.pulse.channels.RegisterSlot.mdx b/docs/api/qiskit/dev/qiskit.pulse.channels.RegisterSlot.mdx index 30d635765ef..f56e89f8e07 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.channels.RegisterSlot.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.channels.RegisterSlot.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.channels.RegisterSlot # RegisterSlot - + Bases: `ClassicalIOChannel` Classical resister slot channels represent classical registers (low-latency classical memory). @@ -49,7 +49,7 @@ python_api_name: qiskit.pulse.channels.RegisterSlot ### is\_parameterized - + Return True iff the channel is parameterized. **Return type** diff --git a/docs/api/qiskit/dev/qiskit.pulse.channels.SnapshotChannel.mdx b/docs/api/qiskit/dev/qiskit.pulse.channels.SnapshotChannel.mdx index 52c45ad58d1..f45f335ed06 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.channels.SnapshotChannel.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.channels.SnapshotChannel.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.channels.SnapshotChannel # SnapshotChannel - + Bases: `ClassicalIOChannel` Snapshot channels are used to specify instructions for simulators. @@ -45,7 +45,7 @@ python_api_name: qiskit.pulse.channels.SnapshotChannel ### is\_parameterized - + Return True iff the channel is parameterized. **Return type** diff --git a/docs/api/qiskit/dev/qiskit.pulse.instructions.Acquire.mdx b/docs/api/qiskit/dev/qiskit.pulse.instructions.Acquire.mdx index 4b640969665..8e018b44386 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.instructions.Acquire.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.instructions.Acquire.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.Acquire # Acquire - + 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: @@ -127,7 +127,7 @@ python_api_name: qiskit.pulse.instructions.Acquire ### append - + 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** @@ -146,7 +146,7 @@ python_api_name: qiskit.pulse.instructions.Acquire ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -160,7 +160,7 @@ python_api_name: qiskit.pulse.instructions.Acquire ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -174,7 +174,7 @@ python_api_name: qiskit.pulse.instructions.Acquire ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -188,7 +188,7 @@ python_api_name: qiskit.pulse.instructions.Acquire ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -208,7 +208,7 @@ python_api_name: qiskit.pulse.instructions.Acquire ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -218,7 +218,7 @@ python_api_name: qiskit.pulse.instructions.Acquire ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.pulse.instructions.Delay.mdx b/docs/api/qiskit/dev/qiskit.pulse.instructions.Delay.mdx index 9fe9b1a875c..019f3658e5f 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.instructions.Delay.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.instructions.Delay.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.Delay # Delay - + 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. @@ -101,7 +101,7 @@ python_api_name: qiskit.pulse.instructions.Delay ### append - + 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** @@ -120,7 +120,7 @@ python_api_name: qiskit.pulse.instructions.Delay ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -134,7 +134,7 @@ python_api_name: qiskit.pulse.instructions.Delay ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -148,7 +148,7 @@ python_api_name: qiskit.pulse.instructions.Delay ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -162,7 +162,7 @@ python_api_name: qiskit.pulse.instructions.Delay ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -182,7 +182,7 @@ python_api_name: qiskit.pulse.instructions.Delay ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -192,7 +192,7 @@ python_api_name: qiskit.pulse.instructions.Delay ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.pulse.instructions.Play.mdx b/docs/api/qiskit/dev/qiskit.pulse.instructions.Play.mdx index 5f8f8d98bab..0bb4dd3793d 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.instructions.Play.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.instructions.Play.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.Play # Play - + Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") This instruction is responsible for applying a pulse on a channel. @@ -95,7 +95,7 @@ python_api_name: qiskit.pulse.instructions.Play ### append - + 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** @@ -114,7 +114,7 @@ python_api_name: qiskit.pulse.instructions.Play ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -128,7 +128,7 @@ python_api_name: qiskit.pulse.instructions.Play ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -142,7 +142,7 @@ python_api_name: qiskit.pulse.instructions.Play ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -156,7 +156,7 @@ python_api_name: qiskit.pulse.instructions.Play ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -176,7 +176,7 @@ python_api_name: qiskit.pulse.instructions.Play ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -186,7 +186,7 @@ python_api_name: qiskit.pulse.instructions.Play ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.pulse.instructions.Reference.mdx b/docs/api/qiskit/dev/qiskit.pulse.instructions.Reference.mdx index db82289d1b2..8ae75b2e049 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.instructions.Reference.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.instructions.Reference.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.Reference # Reference - + Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") Pulse compiler directive that refers to a subroutine. @@ -100,7 +100,7 @@ python_api_name: qiskit.pulse.instructions.Reference ### append - + 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** @@ -119,7 +119,7 @@ python_api_name: qiskit.pulse.instructions.Reference ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -133,7 +133,7 @@ python_api_name: qiskit.pulse.instructions.Reference ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -147,7 +147,7 @@ python_api_name: qiskit.pulse.instructions.Reference ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -161,7 +161,7 @@ python_api_name: qiskit.pulse.instructions.Reference ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -181,7 +181,7 @@ python_api_name: qiskit.pulse.instructions.Reference ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -191,7 +191,7 @@ python_api_name: qiskit.pulse.instructions.Reference ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.pulse.instructions.RelativeBarrier.mdx b/docs/api/qiskit/dev/qiskit.pulse.instructions.RelativeBarrier.mdx index a8e0c6eba8f..d972b315363 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.instructions.RelativeBarrier.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.instructions.RelativeBarrier.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier # RelativeBarrier - + Bases: `Directive` Pulse `RelativeBarrier` directive. @@ -82,7 +82,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier ### append - + 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** @@ -101,7 +101,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -115,7 +115,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -129,7 +129,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -143,7 +143,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -163,7 +163,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -173,7 +173,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.pulse.instructions.SetFrequency.mdx b/docs/api/qiskit/dev/qiskit.pulse.instructions.SetFrequency.mdx index 1ca693de4d5..22f96e8b4f1 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.instructions.SetFrequency.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.instructions.SetFrequency.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.SetFrequency # SetFrequency - + 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 @@ -103,7 +103,7 @@ $$ ### append - + 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** @@ -122,7 +122,7 @@ $$ ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -136,7 +136,7 @@ $$ ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -150,7 +150,7 @@ $$ ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -164,7 +164,7 @@ $$ ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -184,7 +184,7 @@ $$ ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -194,7 +194,7 @@ $$ ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.pulse.instructions.SetPhase.mdx b/docs/api/qiskit/dev/qiskit.pulse.instructions.SetPhase.mdx index 937ea6b4d2c..e0d3d1268f6 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.instructions.SetPhase.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.instructions.SetPhase.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.SetPhase # SetPhase - + 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. @@ -101,7 +101,7 @@ $$ ### append - + 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** @@ -120,7 +120,7 @@ $$ ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -134,7 +134,7 @@ $$ ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -148,7 +148,7 @@ $$ ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -162,7 +162,7 @@ $$ ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -182,7 +182,7 @@ $$ ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -192,7 +192,7 @@ $$ ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.pulse.instructions.ShiftFrequency.mdx b/docs/api/qiskit/dev/qiskit.pulse.instructions.ShiftFrequency.mdx index 59a514c0b13..d6185760ed3 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.instructions.ShiftFrequency.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.instructions.ShiftFrequency.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency # ShiftFrequency - + Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") Shift the channel frequency away from the current frequency. @@ -93,7 +93,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency ### append - + 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** @@ -112,7 +112,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -126,7 +126,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -140,7 +140,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -154,7 +154,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -174,7 +174,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -184,7 +184,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.pulse.instructions.ShiftPhase.mdx b/docs/api/qiskit/dev/qiskit.pulse.instructions.ShiftPhase.mdx index 62a0d329f52..25c4d5e9a31 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.instructions.ShiftPhase.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.instructions.ShiftPhase.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.ShiftPhase # ShiftPhase - + 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. @@ -105,7 +105,7 @@ $$ ### append - + 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** @@ -124,7 +124,7 @@ $$ ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -138,7 +138,7 @@ $$ ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -152,7 +152,7 @@ $$ ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -166,7 +166,7 @@ $$ ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -186,7 +186,7 @@ $$ ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -196,7 +196,7 @@ $$ ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.pulse.instructions.Snapshot.mdx b/docs/api/qiskit/dev/qiskit.pulse.instructions.Snapshot.mdx index fe3ed365d3b..3c211d20119 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.instructions.Snapshot.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.instructions.Snapshot.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot # Snapshot - + Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") An instruction targeted for simulators, to capture a moment in the simulation. @@ -99,7 +99,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot ### append - + 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** @@ -118,7 +118,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -132,7 +132,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -146,7 +146,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -160,7 +160,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -180,7 +180,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -190,7 +190,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.pulse.instructions.TimeBlockade.mdx b/docs/api/qiskit/dev/qiskit.pulse.instructions.TimeBlockade.mdx index 750dd175e62..94c934b8fc3 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.instructions.TimeBlockade.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.instructions.TimeBlockade.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade # TimeBlockade - + Bases: `Directive` Pulse `TimeBlockade` directive. @@ -118,7 +118,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade ### append - + 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** @@ -137,7 +137,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -151,7 +151,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -165,7 +165,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -179,7 +179,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -199,7 +199,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -209,7 +209,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.Constant_class.rst.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.Constant_class.rst.mdx index fdbf208985e..26ae60f4f99 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.Constant_class.rst.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.Constant_class.rst.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.library.Constant # Constant - + 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: diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.Cos_class.rst.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.Cos_class.rst.mdx index 205de27867c..ce5e45c90a9 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.Cos_class.rst.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.Cos_class.rst.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.Cos # qiskit.pulse.library.Cos - + A cosine pulse. The envelope of the pulse is given by: diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.Drag_class.rst.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.Drag_class.rst.mdx index a99ae0f1e12..d92c170dc66 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.Drag_class.rst.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.Drag_class.rst.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.library.Drag # Drag - + 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. diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.GaussianDeriv.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.GaussianDeriv.mdx index 7ea0249af41..07e8cecc46d 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.GaussianDeriv.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.GaussianDeriv.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.GaussianDeriv # qiskit.pulse.library.GaussianDeriv - + 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: diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.GaussianSquare.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.GaussianSquare.mdx index 6ca61d1c16b..06f21ce8ec8 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.GaussianSquare.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.GaussianSquare.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.library.GaussianSquare # GaussianSquare - + 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. diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.GaussianSquareDrag.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.GaussianSquareDrag.mdx index 107f239ebbf..e3b5ecce883 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.GaussianSquareDrag.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.GaussianSquareDrag.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.GaussianSquareDrag # qiskit.pulse.library.GaussianSquareDrag - + 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. diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.Gaussian_class.rst.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.Gaussian_class.rst.mdx index 4469f97e6e1..c3932d2ce99 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.Gaussian_class.rst.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.Gaussian_class.rst.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.library.Gaussian # Gaussian - + 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): diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.Sawtooth_class.rst.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.Sawtooth_class.rst.mdx index 73263b02f5f..c21b68af620 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.Sawtooth_class.rst.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.Sawtooth_class.rst.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.Sawtooth # qiskit.pulse.library.Sawtooth - + A sawtooth pulse. The envelope of the pulse is given by: diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.SechDeriv.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.SechDeriv.mdx index 5d3d5c4f369..c466d4e9a0b 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.SechDeriv.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.SechDeriv.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.SechDeriv # qiskit.pulse.library.SechDeriv - + 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: diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.Sech_fun.rst.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.Sech_fun.rst.mdx index b4839f7d92d..4224beb0c23 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.Sech_fun.rst.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.Sech_fun.rst.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.Sech # qiskit.pulse.library.Sech - + 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: diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.Sin_class.rst.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.Sin_class.rst.mdx index 5244f517729..8fb42aa609c 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.Sin_class.rst.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.Sin_class.rst.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.Sin # qiskit.pulse.library.Sin - + A sinusoidal pulse. The envelope of the pulse is given by: diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.Square_fun.rst.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.Square_fun.rst.mdx index 431a2319420..013d6619d83 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.Square_fun.rst.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.Square_fun.rst.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.Square # qiskit.pulse.library.Square - + A square wave pulse. The envelope of the pulse is given by: diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.SymbolicPulse.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.SymbolicPulse.mdx index af8763a056c..7539a7e06be 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.SymbolicPulse.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.SymbolicPulse.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.library.SymbolicPulse # SymbolicPulse - + Bases: `Pulse` The pulse representation model with parameters and symbolic expressions. @@ -172,7 +172,7 @@ $$ ### draw - + Plot the interpolated envelope of pulse. **Parameters** @@ -208,7 +208,7 @@ $$ ### 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: @@ -233,7 +233,7 @@ $$ ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -243,7 +243,7 @@ $$ ### validate\_parameters - + Validate parameters. **Raises** diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.Triangle_class.rst.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.Triangle_class.rst.mdx index e8cd2fa4428..9c5794ea2e0 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.Triangle_class.rst.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.Triangle_class.rst.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.Triangle # qiskit.pulse.library.Triangle - + A triangle wave pulse. The envelope of the pulse is given by: diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.Waveform.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.Waveform.mdx index 5dabdbcd5ba..cfada2a5687 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.Waveform.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.Waveform.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.library.Waveform # Waveform - + Bases: `Pulse` A pulse specified completely by complex-valued samples; each sample is played for the duration of the backend cycle-time, dt. @@ -58,7 +58,7 @@ python_api_name: qiskit.pulse.library.Waveform ### draw - + Plot the interpolated envelope of pulse. **Parameters** @@ -94,7 +94,7 @@ python_api_name: qiskit.pulse.library.Waveform ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** diff --git a/docs/api/qiskit/dev/qiskit.pulse.library.gaussian_square_echo.mdx b/docs/api/qiskit/dev/qiskit.pulse.library.gaussian_square_echo.mdx index 8f1946ffd8c..d1226890d2a 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.library.gaussian_square_echo.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.library.gaussian_square_echo.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.gaussian_square_echo # qiskit.pulse.library.gaussian\_square\_echo - + 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: diff --git a/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignEquispaced.mdx b/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignEquispaced.mdx index a4e429fd9fb..e1cdf849f5d 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignEquispaced.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignEquispaced.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.transforms.AlignEquispaced # AlignEquispaced - + Bases: [`AlignmentKind`](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") Align instructions with equispaced interval within a specified duration. @@ -37,7 +37,7 @@ python_api_name: qiskit.pulse.transforms.AlignEquispaced ### align - + Reallocate instructions according to the policy. Only top-level sub-schedules are aligned. If sub-schedules are nested, nested schedules are not recursively aligned. diff --git a/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignFunc.mdx b/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignFunc.mdx index a86309f6e18..49fd90ea9d2 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignFunc.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignFunc.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.transforms.AlignFunc # AlignFunc - + Bases: [`AlignmentKind`](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") Allocate instructions at position specified by callback function. @@ -57,7 +57,7 @@ python_api_name: qiskit.pulse.transforms.AlignFunc ### align - + Reallocate instructions according to the policy. Only top-level sub-schedules are aligned. If sub-schedules are nested, nested schedules are not recursively aligned. diff --git a/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignLeft.mdx b/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignLeft.mdx index a035bdc1f7f..794a49c5bab 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignLeft.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignLeft.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.transforms.AlignLeft # AlignLeft - + Bases: [`AlignmentKind`](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") Align instructions in as-soon-as-possible manner. @@ -27,7 +27,7 @@ python_api_name: qiskit.pulse.transforms.AlignLeft ### align - + Reallocate instructions according to the policy. Only top-level sub-schedules are aligned. If sub-schedules are nested, nested schedules are not recursively aligned. diff --git a/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignRight.mdx b/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignRight.mdx index c056ce6c1c3..da436ea40ff 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignRight.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignRight.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.transforms.AlignRight # AlignRight - + Bases: [`AlignmentKind`](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") Align instructions in as-late-as-possible manner. @@ -27,7 +27,7 @@ python_api_name: qiskit.pulse.transforms.AlignRight ### align - + Reallocate instructions according to the policy. Only top-level sub-schedules are aligned. If sub-schedules are nested, nested schedules are not recursively aligned. diff --git a/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignSequential.mdx b/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignSequential.mdx index 41195cff3d3..5a055629184 100644 --- a/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignSequential.mdx +++ b/docs/api/qiskit/dev/qiskit.pulse.transforms.AlignSequential.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.transforms.AlignSequential # AlignSequential - + Bases: [`AlignmentKind`](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") Align instructions sequentially. @@ -27,7 +27,7 @@ python_api_name: qiskit.pulse.transforms.AlignSequential ### align - + Reallocate instructions according to the policy. Only top-level sub-schedules are aligned. If sub-schedules are nested, nested schedules are not recursively aligned. diff --git a/docs/api/qiskit/dev/qiskit.qobj.GateCalibration.mdx b/docs/api/qiskit/dev/qiskit.qobj.GateCalibration.mdx index 32b9447e059..ac92ade0ed8 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.GateCalibration.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.GateCalibration.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.GateCalibration # GateCalibration - + 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. @@ -26,7 +26,7 @@ python_api_name: qiskit.qobj.GateCalibration ### from\_dict - + Create a new GateCalibration object from a dictionary. **Parameters** @@ -44,7 +44,7 @@ python_api_name: qiskit.qobj.GateCalibration ### to\_dict - + Return a dictionary format representation of the Gate Calibration. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.qobj.PulseLibraryItem.mdx b/docs/api/qiskit/dev/qiskit.qobj.PulseLibraryItem.mdx index f9cce4c462f..2feb3fe0127 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.PulseLibraryItem.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.PulseLibraryItem.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.PulseLibraryItem # PulseLibraryItem - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") An item in a pulse library. @@ -24,7 +24,7 @@ python_api_name: qiskit.qobj.PulseLibraryItem ### from\_dict - + Create a new PulseLibraryItem object from a dictionary. **Parameters** @@ -42,7 +42,7 @@ python_api_name: qiskit.qobj.PulseLibraryItem ### to\_dict - + Return a dictionary format representation of the pulse library item. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.qobj.PulseQobj.mdx b/docs/api/qiskit/dev/qiskit.qobj.PulseQobj.mdx index 30712228043..aae369bd13d 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.PulseQobj.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.PulseQobj.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.PulseQobj # PulseQobj - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") A Pulse Qobj. @@ -28,7 +28,7 @@ python_api_name: qiskit.qobj.PulseQobj ### from\_dict - + Create a new PulseQobj object from a dictionary. **Parameters** @@ -46,7 +46,7 @@ python_api_name: qiskit.qobj.PulseQobj ### 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: diff --git a/docs/api/qiskit/dev/qiskit.qobj.PulseQobjConfig.mdx b/docs/api/qiskit/dev/qiskit.qobj.PulseQobjConfig.mdx index a27663f5d8d..13b07eb2464 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.PulseQobjConfig.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.PulseQobjConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.PulseQobjConfig # PulseQobjConfig - + Bases: `QobjDictField` A configuration for a Pulse Qobj. @@ -34,7 +34,7 @@ python_api_name: qiskit.qobj.PulseQobjConfig ### from\_dict - + Create a new PulseQobjConfig object from a dictionary. **Parameters** @@ -52,7 +52,7 @@ python_api_name: qiskit.qobj.PulseQobjConfig ### to\_dict - + Return a dictionary format representation of the Pulse Qobj config. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.qobj.PulseQobjExperiment.mdx b/docs/api/qiskit/dev/qiskit.qobj.PulseQobjExperiment.mdx index d93cece75a3..4a196f576c3 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.PulseQobjExperiment.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.PulseQobjExperiment.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.PulseQobjExperiment # PulseQobjExperiment - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") A Pulse Qobj Experiment. @@ -27,7 +27,7 @@ python_api_name: qiskit.qobj.PulseQobjExperiment ### from\_dict - + Create a new PulseQobjExperiment object from a dictionary. **Parameters** @@ -45,7 +45,7 @@ python_api_name: qiskit.qobj.PulseQobjExperiment ### to\_dict - + Return a dictionary format representation of the Experiment. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.qobj.PulseQobjExperimentConfig.mdx b/docs/api/qiskit/dev/qiskit.qobj.PulseQobjExperimentConfig.mdx index b8bf493077f..94cca26444c 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.PulseQobjExperimentConfig.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.PulseQobjExperimentConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.PulseQobjExperimentConfig # PulseQobjExperimentConfig - + Bases: `QobjDictField` A config for a single Pulse experiment in the qobj. @@ -25,7 +25,7 @@ python_api_name: qiskit.qobj.PulseQobjExperimentConfig ### from\_dict - + Create a new QobjHeader object from a dictionary. **Parameters** @@ -43,7 +43,7 @@ python_api_name: qiskit.qobj.PulseQobjExperimentConfig ### to\_dict - + Return a dictionary format representation of the OpenQASM 2 Qobj. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.qobj.PulseQobjInstruction.mdx b/docs/api/qiskit/dev/qiskit.qobj.PulseQobjInstruction.mdx index dc380509210..cf1f8645f3b 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.PulseQobjInstruction.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.PulseQobjInstruction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.PulseQobjInstruction # PulseQobjInstruction - + 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. @@ -39,7 +39,7 @@ python_api_name: qiskit.qobj.PulseQobjInstruction ### from\_dict - + Create a new PulseQobjExperimentConfig object from a dictionary. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.qobj.PulseQobjInstruction ### to\_dict - + Return a dictionary format representation of the Instruction. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.qobj.QasmExperimentCalibrations.mdx b/docs/api/qiskit/dev/qiskit.qobj.QasmExperimentCalibrations.mdx index 9efe1f5ef33..8961fcff882 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.QasmExperimentCalibrations.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.QasmExperimentCalibrations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QasmExperimentCalibrations # QasmExperimentCalibrations - + 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. @@ -23,7 +23,7 @@ python_api_name: qiskit.qobj.QasmExperimentCalibrations ### from\_dict - + Create a new GateCalibration object from a dictionary. **Parameters** @@ -41,7 +41,7 @@ python_api_name: qiskit.qobj.QasmExperimentCalibrations ### to\_dict - + Return a dictionary format representation of the calibrations. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.qobj.QasmQobj.mdx b/docs/api/qiskit/dev/qiskit.qobj.QasmQobj.mdx index 1a36333c9aa..6f8a82834e6 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.QasmQobj.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.QasmQobj.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QasmQobj # QasmQobj - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") An OpenQASM 2 Qobj. @@ -28,7 +28,7 @@ python_api_name: qiskit.qobj.QasmQobj ### from\_dict - + Create a new QASMQobj object from a dictionary. **Parameters** @@ -46,7 +46,7 @@ python_api_name: qiskit.qobj.QasmQobj ### 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: diff --git a/docs/api/qiskit/dev/qiskit.qobj.QasmQobjConfig.mdx b/docs/api/qiskit/dev/qiskit.qobj.QasmQobjConfig.mdx index 3c924b5937b..64c347aa0d4 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.QasmQobjConfig.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.QasmQobjConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QasmQobjConfig # QasmQobjConfig - + Bases: [`SimpleNamespace`](https://docs.python.org/3/library/types.html#types.SimpleNamespace "(in Python v3.12)") A configuration for an OpenQASM 2 Qobj. @@ -36,7 +36,7 @@ python_api_name: qiskit.qobj.QasmQobjConfig ### from\_dict - + Create a new QasmQobjConfig object from a dictionary. **Parameters** @@ -54,7 +54,7 @@ python_api_name: qiskit.qobj.QasmQobjConfig ### to\_dict - + Return a dictionary format representation of the OpenQASM 2 Qobj config. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.qobj.QasmQobjExperiment.mdx b/docs/api/qiskit/dev/qiskit.qobj.QasmQobjExperiment.mdx index a658dcd9605..572f3632e66 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.QasmQobjExperiment.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.QasmQobjExperiment.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QasmQobjExperiment # QasmQobjExperiment - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") An OpenQASM 2 Qobj Experiment. @@ -27,7 +27,7 @@ python_api_name: qiskit.qobj.QasmQobjExperiment ### from\_dict - + Create a new QasmQobjExperiment object from a dictionary. **Parameters** @@ -45,7 +45,7 @@ python_api_name: qiskit.qobj.QasmQobjExperiment ### to\_dict - + Return a dictionary format representation of the Experiment. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.qobj.QasmQobjExperimentConfig.mdx b/docs/api/qiskit/dev/qiskit.qobj.QasmQobjExperimentConfig.mdx index 616ab336a34..fb4862f8d38 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.QasmQobjExperimentConfig.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.QasmQobjExperimentConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QasmQobjExperimentConfig # QasmQobjExperimentConfig - + Bases: `QobjDictField` Configuration for a single OpenQASM 2 experiment in the qobj. @@ -24,7 +24,7 @@ python_api_name: qiskit.qobj.QasmQobjExperimentConfig ### from\_dict - + Create a new QobjHeader object from a dictionary. **Parameters** @@ -42,7 +42,7 @@ python_api_name: qiskit.qobj.QasmQobjExperimentConfig ### to\_dict - + Return a dictionary format representation of the OpenQASM 2 Qobj. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.qobj.QasmQobjInstruction.mdx b/docs/api/qiskit/dev/qiskit.qobj.QasmQobjInstruction.mdx index 719a5a25bbf..d094699917a 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.QasmQobjInstruction.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.QasmQobjInstruction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QasmQobjInstruction # QasmQobjInstruction - + 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. @@ -34,7 +34,7 @@ python_api_name: qiskit.qobj.QasmQobjInstruction ### from\_dict - + Create a new QasmQobjInstruction object from a dictionary. **Parameters** @@ -52,7 +52,7 @@ python_api_name: qiskit.qobj.QasmQobjInstruction ### to\_dict - + Return a dictionary format representation of the Instruction. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.qobj.QobjExperimentHeader.mdx b/docs/api/qiskit/dev/qiskit.qobj.QobjExperimentHeader.mdx index 34ecd298cd0..8f890010ef1 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.QobjExperimentHeader.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.QobjExperimentHeader.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QobjExperimentHeader # QobjExperimentHeader - + Bases: [`QobjHeader`](qiskit.qobj.QobjHeader "qiskit.qobj.common.QobjHeader") A class representing a header dictionary for a Qobj Experiment. @@ -23,7 +23,7 @@ python_api_name: qiskit.qobj.QobjExperimentHeader ### from\_dict - + Create a new QobjHeader object from a dictionary. **Parameters** @@ -41,7 +41,7 @@ python_api_name: qiskit.qobj.QobjExperimentHeader ### to\_dict - + Return a dictionary format representation of the OpenQASM 2 Qobj. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.qobj.QobjHeader.mdx b/docs/api/qiskit/dev/qiskit.qobj.QobjHeader.mdx index 7e50b6a3349..8a05f61d0f6 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.QobjHeader.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.QobjHeader.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QobjHeader # QobjHeader - + Bases: `QobjDictField` A class used to represent a dictionary header in Qobj objects. @@ -23,7 +23,7 @@ python_api_name: qiskit.qobj.QobjHeader ### from\_dict - + Create a new QobjHeader object from a dictionary. **Parameters** @@ -41,7 +41,7 @@ python_api_name: qiskit.qobj.QobjHeader ### to\_dict - + Return a dictionary format representation of the OpenQASM 2 Qobj. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.qobj.QobjMeasurementOption.mdx b/docs/api/qiskit/dev/qiskit.qobj.QobjMeasurementOption.mdx index 7b0042a8e79..9e0b49bc766 100644 --- a/docs/api/qiskit/dev/qiskit.qobj.QobjMeasurementOption.mdx +++ b/docs/api/qiskit/dev/qiskit.qobj.QobjMeasurementOption.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QobjMeasurementOption # QobjMeasurementOption - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") An individual measurement option. @@ -24,7 +24,7 @@ python_api_name: qiskit.qobj.QobjMeasurementOption ### from\_dict - + Create a new QobjMeasurementOption object from a dictionary. **Parameters** @@ -42,7 +42,7 @@ python_api_name: qiskit.qobj.QobjMeasurementOption ### to\_dict - + Return a dict format representation of the QobjMeasurementOption. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.CNOTDihedral.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.CNOTDihedral.mdx index 0dba9e8839d..bdc0101e0a4 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.CNOTDihedral.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.CNOTDihedral.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.CNOTDihedral # CNOTDihedral - + Bases: `BaseOperator`, `AdjointMixin` An N-qubit operator from the CNOT-Dihedral group. @@ -106,13 +106,13 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### adjoint - + Return the adjoint of the Operator. ### compose - + Return the operator composition with another CNOTDihedral. **Parameters** @@ -142,19 +142,19 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### conjugate - + Return the conjugate of the CNOTDihedral. ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -177,7 +177,7 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### expand - + Return the reverse-order tensor product with another CNOTDihedral. **Parameters** @@ -197,19 +197,19 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### input\_dims - + Return tuple of input dimension for specified subsystems. ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the compose of a operator with itself n times. **Parameters** @@ -231,7 +231,7 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -255,7 +255,7 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### tensor - + Return the tensor product with another CNOTDihedral. **Parameters** @@ -279,7 +279,7 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### to\_circuit - + Return a QuantumCircuit implementing the CNOT-Dihedral element. **Returns** @@ -298,19 +298,19 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### to\_instruction - + Return a Gate instruction implementing the CNOTDihedral object. ### to\_matrix - + Convert operator to Numpy matrix. ### to\_operator - + Convert to an Operator object. **Return type** @@ -320,7 +320,7 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### transpose - + Return the transpose of the CNOTDihedral. diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.Chi.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.Chi.mdx index 40ca803efd9..64b5aabae99 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.Chi.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.Chi.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Chi # Chi - + Bases: `QuantumChannel` Pauli basis Chi-matrix representation of a quantum channel. @@ -87,7 +87,7 @@ $$ ### adjoint - + Return the adjoint quantum channel. @@ -97,7 +97,7 @@ $$ ### compose - + Return the operator composition with another Chi. **Parameters** @@ -127,7 +127,7 @@ $$ ### conjugate - + Return the conjugate quantum channel. @@ -137,13 +137,13 @@ $$ ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -166,7 +166,7 @@ $$ ### expand - + Return the reverse-order tensor product with another Chi. **Parameters** @@ -186,13 +186,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_cp - + Test if Choi-matrix is completely-positive (CP) **Return type** @@ -202,7 +202,7 @@ $$ ### is\_cptp - + Return True if completely-positive trace-preserving (CPTP). **Return type** @@ -212,7 +212,7 @@ $$ ### is\_tp - + Test if a channel is trace-preserving (TP) **Return type** @@ -222,7 +222,7 @@ $$ ### is\_unitary - + Return True if QuantumChannel is a unitary channel. **Return type** @@ -232,13 +232,13 @@ $$ ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the power of the quantum channel. **Parameters** @@ -264,7 +264,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -288,7 +288,7 @@ $$ ### tensor - + Return the tensor product with another Chi. **Parameters** @@ -312,7 +312,7 @@ $$ ### 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. @@ -332,7 +332,7 @@ $$ ### to\_operator - + Try to convert channel to a unitary representation Operator. **Return type** @@ -342,7 +342,7 @@ $$ ### transpose - + Return the transpose quantum channel. diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.Choi.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.Choi.mdx index fab577f2737..46fca3acade 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.Choi.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.Choi.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Choi # Choi - + Bases: `QuantumChannel` Choi-matrix representation of a Quantum Channel. @@ -95,7 +95,7 @@ $$ ### adjoint - + Return the adjoint quantum channel. @@ -109,7 +109,7 @@ $$ ### compose - + Return the operator composition with another Choi. **Parameters** @@ -139,7 +139,7 @@ $$ ### conjugate - + Return the conjugate quantum channel. @@ -149,13 +149,13 @@ $$ ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -178,7 +178,7 @@ $$ ### expand - + Return the reverse-order tensor product with another Choi. **Parameters** @@ -198,13 +198,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_cp - + Test if Choi-matrix is completely-positive (CP) **Return type** @@ -214,7 +214,7 @@ $$ ### is\_cptp - + Return True if completely-positive trace-preserving (CPTP). **Return type** @@ -224,7 +224,7 @@ $$ ### is\_tp - + Test if a channel is trace-preserving (TP) **Return type** @@ -234,7 +234,7 @@ $$ ### is\_unitary - + Return True if QuantumChannel is a unitary channel. **Return type** @@ -244,13 +244,13 @@ $$ ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the power of the quantum channel. **Parameters** @@ -276,7 +276,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -300,7 +300,7 @@ $$ ### tensor - + Return the tensor product with another Choi. **Parameters** @@ -324,7 +324,7 @@ $$ ### 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. @@ -344,7 +344,7 @@ $$ ### to\_operator - + Try to convert channel to a unitary representation Operator. **Return type** @@ -354,7 +354,7 @@ $$ ### transpose - + Return the transpose quantum channel. diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.Clifford.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.Clifford.mdx index d02897a095d..3f663ff4cf1 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.Clifford.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.Clifford.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Clifford # Clifford - + Bases: `BaseOperator`, `AdjointMixin`, [`Operation`](qiskit.circuit.Operation "qiskit.circuit.operation.Operation") An N-qubit unitary operator from the Clifford group. @@ -182,13 +182,13 @@ python_api_name: qiskit.quantum_info.Clifford ### adjoint - + Return the adjoint of the Operator. ### compose - + Return the operator composition with another Clifford. **Parameters** @@ -218,19 +218,19 @@ python_api_name: qiskit.quantum_info.Clifford ### conjugate - + Return the conjugate of the Clifford. ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -253,7 +253,7 @@ python_api_name: qiskit.quantum_info.Clifford ### expand - + Return the reverse-order tensor product with another Clifford. **Parameters** @@ -273,7 +273,7 @@ python_api_name: qiskit.quantum_info.Clifford ### from\_circuit - + Initialize from a QuantumCircuit or Instruction. **Parameters** @@ -295,13 +295,13 @@ python_api_name: qiskit.quantum_info.Clifford ### from\_dict - + Load a Clifford from a dictionary ### from\_label - + Return a tensor product of single-qubit Clifford gates. **Parameters** @@ -349,7 +349,7 @@ python_api_name: qiskit.quantum_info.Clifford ### from\_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}]]. @@ -369,7 +369,7 @@ python_api_name: qiskit.quantum_info.Clifford ### from\_matrix - + Create a Clifford from a unitary matrix. Note that this function takes exponentially long time w\.r.t. the number of qubits. @@ -393,7 +393,7 @@ python_api_name: qiskit.quantum_info.Clifford ### from\_operator - + Create a Clifford from a operator. Note that this function takes exponentially long time w\.r.t. the number of qubits. @@ -417,7 +417,7 @@ python_api_name: qiskit.quantum_info.Clifford ### from\_permutation - + Create a Clifford from a PermutationGate. **Parameters** @@ -435,25 +435,25 @@ python_api_name: qiskit.quantum_info.Clifford ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_unitary - + Return True if the Clifford table is valid. ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the compose of a operator with itself n times. **Parameters** @@ -475,7 +475,7 @@ python_api_name: qiskit.quantum_info.Clifford ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -499,7 +499,7 @@ python_api_name: qiskit.quantum_info.Clifford ### tensor - + Return the tensor product with another Clifford. **Parameters** @@ -523,7 +523,7 @@ python_api_name: qiskit.quantum_info.Clifford ### 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]. @@ -544,19 +544,19 @@ python_api_name: qiskit.quantum_info.Clifford ### to\_dict - + Return dictionary representation of Clifford object. ### to\_instruction - + Return a Gate instruction implementing the Clifford. ### to\_labels - + 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. @@ -592,13 +592,13 @@ python_api_name: qiskit.quantum_info.Clifford ### to\_matrix - + Convert operator to Numpy matrix. ### to\_operator - + Convert to an Operator object. **Return type** @@ -608,7 +608,7 @@ python_api_name: qiskit.quantum_info.Clifford ### transpose - + Return the transpose of the Clifford. diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.DensityMatrix.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.DensityMatrix.mdx index 2f769b670d8..624c1757821 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.DensityMatrix.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.DensityMatrix.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix # DensityMatrix - + Bases: `QuantumState`, `TolerancesMixin` DensityMatrix class @@ -69,25 +69,25 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### conjugate - + Return the conjugate of the density matrix. ### copy - + Make a copy of current operator. ### dims - + Return tuple of input dimension for specified subsystems. ### draw - + Return a visualization of the Statevector. **repr**: ASCII TextMatrix of the state’s `__repr__`. @@ -120,7 +120,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### evolve - + Evolve a quantum state by an operator. **Parameters** @@ -143,7 +143,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### expand - + Return the tensor product state other ⊗ self. **Parameters** @@ -165,7 +165,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### expectation\_value - + Compute the expectation value of an operator. **Parameters** @@ -184,7 +184,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### from\_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. @@ -208,7 +208,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### from\_int - + Return a computational basis state density matrix. **Parameters** @@ -234,7 +234,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### from\_label - + Return a tensor product of Pauli X,Y,Z eigenstates. | Label | Statevector | @@ -265,13 +265,13 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### is\_valid - + Return True if trace 1 and positive semidefinite. ### measure - + 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. @@ -293,7 +293,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### partial\_transpose - + Return partially transposed density matrix. **Parameters** @@ -311,7 +311,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### probabilities - + Return the subsystem measurement probability vector. Measurement probabilities are with respect to measurement in the computation (diagonal) basis. @@ -382,7 +382,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### probabilities\_dict - + Return the subsystem measurement probability dictionary. Measurement probabilities are with respect to measurement in the computation (diagonal) basis. @@ -405,13 +405,13 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### purity - + Return the purity of the quantum state. ### reset - + Reset state or subsystems to the 0-state. **Parameters** @@ -433,7 +433,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### 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}$. @@ -449,7 +449,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### sample\_counts - + Sample a dict of qubit measurement outcomes in the computational basis. **Parameters** @@ -474,7 +474,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### sample\_memory - + Sample a list of qubit measurement outcomes in the computational basis. **Parameters** @@ -499,13 +499,13 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### seed - + Set the seed for the quantum state RNG. ### tensor - + Return the tensor product state self ⊗ other. **Parameters** @@ -527,7 +527,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### to\_dict - + 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. @@ -603,7 +603,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### to\_operator - + Convert to Operator **Return type** @@ -613,7 +613,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### to\_statevector - + Return a statevector from a pure density matrix. **Parameters** @@ -638,7 +638,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### trace - + Return the trace of the density matrix. diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.Kraus.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.Kraus.mdx index 66fbe034291..d2b9ebf1d78 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.Kraus.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.Kraus.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Kraus # Kraus - + Bases: `QuantumChannel` Kraus representation of a quantum channel. @@ -91,7 +91,7 @@ $$ ### adjoint - + Return the adjoint quantum channel. @@ -101,7 +101,7 @@ $$ ### compose - + Return the operator composition with another Kraus. **Parameters** @@ -131,7 +131,7 @@ $$ ### conjugate - + Return the conjugate quantum channel. @@ -141,13 +141,13 @@ $$ ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -170,7 +170,7 @@ $$ ### expand - + Return the reverse-order tensor product with another Kraus. **Parameters** @@ -190,13 +190,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_cp - + Test if Choi-matrix is completely-positive (CP) **Return type** @@ -206,13 +206,13 @@ $$ ### is\_cptp - + Return True if completely-positive trace-preserving. ### is\_tp - + Test if a channel is trace-preserving (TP) **Return type** @@ -222,7 +222,7 @@ $$ ### is\_unitary - + Return True if QuantumChannel is a unitary channel. **Return type** @@ -232,13 +232,13 @@ $$ ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the power of the quantum channel. **Parameters** @@ -264,7 +264,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -288,7 +288,7 @@ $$ ### tensor - + Return the tensor product with another Kraus. **Parameters** @@ -312,7 +312,7 @@ $$ ### 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. @@ -332,7 +332,7 @@ $$ ### to\_operator - + Try to convert channel to a unitary representation Operator. **Return type** @@ -342,7 +342,7 @@ $$ ### transpose - + Return the transpose quantum channel. diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.Operator.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.Operator.mdx index aed6aa86f43..d3013671aab 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.Operator.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.Operator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Operator # Operator - + Bases: `LinearOp` Matrix operator class @@ -85,7 +85,7 @@ $$ ### adjoint - + Return the adjoint of the Operator. **Return type** @@ -95,7 +95,7 @@ $$ ### apply\_permutation - + Modifies operator’s data by composing it with a permutation. **Parameters** @@ -118,7 +118,7 @@ $$ ### compose - + Return the operator composition with another Operator. **Parameters** @@ -148,19 +148,19 @@ $$ ### conjugate - + Return the conjugate of the Operator. ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -183,7 +183,7 @@ $$ ### draw - + Return a visualization of the Operator. **repr**: String of the state’s `__repr__`. @@ -214,7 +214,7 @@ $$ ### equiv - + Return True if operators are equivalent up to global phase. **Parameters** @@ -234,7 +234,7 @@ $$ ### expand - + Return the reverse-order tensor product with another Operator. **Parameters** @@ -254,7 +254,7 @@ $$ ### from\_circuit - + 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. @@ -279,7 +279,7 @@ $$ ### from\_label - + Return a tensor product of single-qubit operators. **Parameters** @@ -305,25 +305,25 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_unitary - + Return True if operator is a unitary matrix. ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the matrix power of the operator. **Parameters** @@ -345,7 +345,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -369,7 +369,7 @@ $$ ### 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}$. @@ -385,7 +385,7 @@ $$ ### tensor - + Return the tensor product with another Operator. **Parameters** @@ -409,19 +409,19 @@ $$ ### to\_instruction - + Convert to a UnitaryGate instruction. ### to\_matrix - + Convert operator to NumPy matrix. ### to\_operator - + Convert operator to matrix operator class **Return type** @@ -431,7 +431,7 @@ $$ ### transpose - + Return the transpose of the Operator. diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.PTM.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.PTM.mdx index b8b14aa9a2f..5e739b375c2 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.PTM.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.PTM.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.PTM # PTM - + Bases: `QuantumChannel` Pauli Transfer Matrix (PTM) representation of a Quantum Channel. @@ -95,7 +95,7 @@ $$ ### adjoint - + Return the adjoint quantum channel. @@ -105,7 +105,7 @@ $$ ### compose - + Return the operator composition with another PTM. **Parameters** @@ -135,7 +135,7 @@ $$ ### conjugate - + Return the conjugate quantum channel. @@ -145,13 +145,13 @@ $$ ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -174,7 +174,7 @@ $$ ### expand - + Return the reverse-order tensor product with another PTM. **Parameters** @@ -194,13 +194,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_cp - + Test if Choi-matrix is completely-positive (CP) **Return type** @@ -210,7 +210,7 @@ $$ ### is\_cptp - + Return True if completely-positive trace-preserving (CPTP). **Return type** @@ -220,7 +220,7 @@ $$ ### is\_tp - + Test if a channel is trace-preserving (TP) **Return type** @@ -230,7 +230,7 @@ $$ ### is\_unitary - + Return True if QuantumChannel is a unitary channel. **Return type** @@ -240,13 +240,13 @@ $$ ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the power of the quantum channel. **Parameters** @@ -272,7 +272,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -296,7 +296,7 @@ $$ ### tensor - + Return the tensor product with another PTM. **Parameters** @@ -320,7 +320,7 @@ $$ ### 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. @@ -340,7 +340,7 @@ $$ ### to\_operator - + Try to convert channel to a unitary representation Operator. **Return type** @@ -350,7 +350,7 @@ $$ ### transpose - + Return the transpose quantum channel. diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.Pauli.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.Pauli.mdx index bb5db52c9e7..1a3b5de6ab6 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.Pauli.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.Pauli.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Pauli # Pauli - + Bases: `BasePauli` N-qubit Pauli operator. @@ -169,13 +169,13 @@ $$ ### adjoint - + Return the adjoint of the Operator. ### anticommutes - + Return True if other Pauli anticommutes with self. **Parameters** @@ -194,7 +194,7 @@ $$ ### apply\_layout - + Apply a transpiler layout to this [`Pauli`](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") **Parameters** @@ -213,7 +213,7 @@ $$ ### commutes - + Return True if the Pauli commutes with other. **Parameters** @@ -232,7 +232,7 @@ $$ ### compose - + Return the operator composition with another Pauli. **Parameters** @@ -263,19 +263,19 @@ $$ ### conjugate - + Return the conjugate of each Pauli in the list. ### copy - + Make a deep copy of current operator. ### delete - + Return a Pauli with qubits deleted. **Parameters** @@ -297,7 +297,7 @@ $$ ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -317,7 +317,7 @@ $$ ### equiv - + Return True if Pauli’s are equivalent up to group phase. **Parameters** @@ -335,7 +335,7 @@ $$ ### evolve - + 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. @@ -366,7 +366,7 @@ $$ ### expand - + Return the reverse-order tensor product with another Pauli. **Parameters** @@ -386,13 +386,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### insert - + Insert a Pauli at specific qubit value. **Parameters** @@ -415,19 +415,19 @@ $$ ### inverse - + Return the inverse of the Pauli. ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the compose of a operator with itself n times. **Parameters** @@ -449,7 +449,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -473,7 +473,7 @@ $$ ### set\_truncation - + Set the max number of Pauli characters to display before truncation/ **Parameters** @@ -487,7 +487,7 @@ $$ ### tensor - + Return the tensor product with another Pauli. **Parameters** @@ -511,13 +511,13 @@ $$ ### to\_instruction - + Convert to Pauli circuit instruction. ### to\_label - + Convert a Pauli to a string label. @@ -535,7 +535,7 @@ $$ ### to\_matrix - + Convert to a Numpy array or sparse CSR matrix. **Parameters** @@ -553,7 +553,7 @@ $$ ### transpose - + Return the transpose of each Pauli in the list. diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.PauliList.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.PauliList.mdx index a6e6abdf13d..550c3c7316d 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.PauliList.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.PauliList.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.PauliList # PauliList - + Bases: `BasePauli`, `LinearMixin`, `GroupMixin` List of N-qubit Pauli operators. @@ -161,13 +161,13 @@ python_api_name: qiskit.quantum_info.PauliList ### adjoint - + Return the adjoint of each Pauli in the list. ### anticommutes - + Return `True` if other Pauli that anticommutes with other. **Parameters** @@ -186,7 +186,7 @@ python_api_name: qiskit.quantum_info.PauliList ### anticommutes\_with\_all - + 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. @@ -206,7 +206,7 @@ python_api_name: qiskit.quantum_info.PauliList ### argsort - + 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. @@ -227,7 +227,7 @@ python_api_name: qiskit.quantum_info.PauliList ### commutes - + Return True for each Pauli that commutes with other. **Parameters** @@ -246,7 +246,7 @@ python_api_name: qiskit.quantum_info.PauliList ### commutes\_with\_all - + 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. @@ -266,7 +266,7 @@ python_api_name: qiskit.quantum_info.PauliList ### compose - + Return the composition self∘other for each Pauli in the list. **Parameters** @@ -291,19 +291,19 @@ python_api_name: qiskit.quantum_info.PauliList ### conjugate - + Return the conjugate of each Pauli in the list. ### copy - + Make a deep copy of current operator. ### delete - + 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. @@ -328,7 +328,7 @@ python_api_name: qiskit.quantum_info.PauliList ### dot - + Return the composition other∘self for each Pauli in the list. **Parameters** @@ -352,7 +352,7 @@ python_api_name: qiskit.quantum_info.PauliList ### equiv - + Entrywise comparison of Pauli equivalence up to global phase. **Parameters** @@ -372,7 +372,7 @@ python_api_name: qiskit.quantum_info.PauliList ### evolve - + 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. @@ -402,7 +402,7 @@ python_api_name: qiskit.quantum_info.PauliList ### expand - + Return the expand product of each Pauli in the list. **Parameters** @@ -424,7 +424,7 @@ python_api_name: qiskit.quantum_info.PauliList ### from\_symplectic - + Construct a PauliList from a symplectic data. **Parameters** @@ -444,7 +444,7 @@ python_api_name: qiskit.quantum_info.PauliList ### group\_commuting - + Partition a PauliList into sets of commuting Pauli strings. **Parameters** @@ -473,7 +473,7 @@ python_api_name: qiskit.quantum_info.PauliList ### group\_qubit\_wise\_commuting - + Partition a PauliList into sets of mutually qubit-wise commuting Pauli strings. **Returns** @@ -487,13 +487,13 @@ python_api_name: qiskit.quantum_info.PauliList ### input\_dims - + Return tuple of input dimension for specified subsystems. ### insert - + 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. @@ -519,13 +519,13 @@ python_api_name: qiskit.quantum_info.PauliList ### inverse - + Return the inverse of each Pauli in the list. ### 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. @@ -541,7 +541,7 @@ python_api_name: qiskit.quantum_info.PauliList ### matrix\_iter - + 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. @@ -561,7 +561,7 @@ python_api_name: qiskit.quantum_info.PauliList ### noncommutation\_graph - + Create the non-commutation graph of this PauliList. This transforms the measurement operator grouping problem into graph coloring problem. The constructed graph contains one node for each Pauli. The nodes will be connecting for any two Pauli terms that do \_not\_ commute. @@ -583,13 +583,13 @@ python_api_name: qiskit.quantum_info.PauliList ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the compose of a operator with itself n times. **Parameters** @@ -611,7 +611,7 @@ python_api_name: qiskit.quantum_info.PauliList ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -635,7 +635,7 @@ python_api_name: qiskit.quantum_info.PauliList ### sort - + 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. @@ -696,7 +696,7 @@ python_api_name: qiskit.quantum_info.PauliList ### tensor - + Return the tensor product with each Pauli in the list. **Parameters** @@ -718,7 +718,7 @@ python_api_name: qiskit.quantum_info.PauliList ### to\_labels - + 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. @@ -745,7 +745,7 @@ python_api_name: qiskit.quantum_info.PauliList ### to\_matrix - + 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. @@ -773,13 +773,13 @@ python_api_name: qiskit.quantum_info.PauliList ### transpose - + Return the transpose of each Pauli in the list. ### unique - + Return unique Paulis from the table. **Example** diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.Quaternion.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.Quaternion.mdx index baf0c2ae491..d6bf679d02a 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.Quaternion.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.Quaternion.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Quaternion # Quaternion - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") A class representing a Quaternion. @@ -17,7 +17,7 @@ python_api_name: qiskit.quantum_info.Quaternion ### from\_axis\_rotation - + Return quaternion for rotation about given axis. **Parameters** @@ -40,7 +40,7 @@ python_api_name: qiskit.quantum_info.Quaternion ### from\_euler - + Generate a quaternion from a set of Euler angles. **Parameters** @@ -59,13 +59,13 @@ python_api_name: qiskit.quantum_info.Quaternion ### norm - + Norm of quaternion. ### normalize - + Normalizes a Quaternion to unit length so that it represents a valid rotation. **Parameters** @@ -83,7 +83,7 @@ python_api_name: qiskit.quantum_info.Quaternion ### to\_matrix - + Converts a unit-length quaternion to a rotation matrix. **Returns** @@ -97,7 +97,7 @@ python_api_name: qiskit.quantum_info.Quaternion ### to\_zyz - + Converts a unit-length quaternion to a sequence of ZYZ Euler angles. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.ScalarOp.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.ScalarOp.mdx index 0b245c45094..6280843fc2d 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.ScalarOp.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.ScalarOp.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.ScalarOp # ScalarOp - + Bases: `LinearOp` Scalar identity operator class. @@ -64,7 +64,7 @@ python_api_name: qiskit.quantum_info.ScalarOp ### adjoint - + Return the adjoint of the Operator. **Return type** @@ -74,7 +74,7 @@ python_api_name: qiskit.quantum_info.ScalarOp ### compose - + Return the operator composition with another ScalarOp. **Parameters** @@ -104,19 +104,19 @@ python_api_name: qiskit.quantum_info.ScalarOp ### conjugate - + Return the conjugate of the ScalarOp. ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -139,7 +139,7 @@ python_api_name: qiskit.quantum_info.ScalarOp ### expand - + Return the reverse-order tensor product with another ScalarOp. **Parameters** @@ -159,25 +159,25 @@ python_api_name: qiskit.quantum_info.ScalarOp ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_unitary - + Return True if operator is a unitary matrix. ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the power of the ScalarOp. **Parameters** @@ -195,7 +195,7 @@ python_api_name: qiskit.quantum_info.ScalarOp ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -219,7 +219,7 @@ python_api_name: qiskit.quantum_info.ScalarOp ### tensor - + Return the tensor product with another ScalarOp. **Parameters** @@ -243,13 +243,13 @@ python_api_name: qiskit.quantum_info.ScalarOp ### to\_matrix - + Convert to a Numpy matrix. ### to\_operator - + Convert to an Operator object. **Return type** @@ -259,7 +259,7 @@ python_api_name: qiskit.quantum_info.ScalarOp ### transpose - + Return the transpose of the ScalarOp. diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.SparsePauliOp.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.SparsePauliOp.mdx index 56bc91fa22e..2cffce280ee 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.SparsePauliOp.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.SparsePauliOp.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp # SparsePauliOp - + Bases: `LinearOp` Sparse N-qubit operator in a Pauli basis representation. @@ -127,13 +127,13 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### adjoint - + Return the adjoint of the Operator. ### apply\_layout - + Apply a transpiler layout to this [`SparsePauliOp`](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") **Parameters** @@ -152,7 +152,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### argsort - + 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. @@ -220,7 +220,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### assign\_parameters - + Bind the free `Parameter`s in the coefficients to provided values. **Parameters** @@ -239,7 +239,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### chop - + 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`. @@ -261,7 +261,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### compose - + Return the operator composition with another SparsePauliOp. **Parameters** @@ -291,19 +291,19 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### conjugate - + Return the conjugate of the SparsePauliOp. ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -326,7 +326,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### equiv - + Check if two SparsePauliOp operators are equivalent. **Parameters** @@ -345,7 +345,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### expand - + Return the reverse-order tensor product with another SparsePauliOp. **Parameters** @@ -365,7 +365,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### from\_list - + Construct from a list of Pauli strings and coefficients. For example, the 5-qubit Hamiltonian @@ -403,7 +403,7 @@ $$ ### from\_operator - + Construct from an Operator objector. Note that the cost of this construction is exponential in general because the number of possible Pauli terms in the decomposition is exponential in the number of qubits. @@ -431,7 +431,7 @@ $$ ### from\_sparse\_list - + 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. @@ -476,7 +476,7 @@ $$ ### group\_commuting - + Partition a SparsePauliOp into sets of commuting Pauli strings. **Parameters** @@ -509,13 +509,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_unitary - + Return True if operator is a unitary matrix. **Parameters** @@ -534,7 +534,7 @@ $$ ### 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. @@ -550,7 +550,7 @@ $$ ### matrix\_iter - + 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. @@ -570,7 +570,7 @@ $$ ### noncommutation\_graph - + Create the non-commutation graph of this SparsePauliOp. This transforms the measurement operator grouping problem into graph coloring problem. The constructed graph contains one node for each Pauli. The nodes will be connecting for any two Pauli terms that do \_not\_ commute. @@ -592,13 +592,13 @@ $$ ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the compose of a operator with itself n times. **Parameters** @@ -620,7 +620,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -644,7 +644,7 @@ $$ ### simplify - + Simplify PauliList by combining duplicates and removing zeros. **Parameters** @@ -663,7 +663,7 @@ $$ ### sort - + 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. @@ -734,7 +734,7 @@ $$ ### sum - + Sum of SparsePauliOps. This is a specialized version of the builtin `sum` function for SparsePauliOp with smaller overhead. @@ -760,7 +760,7 @@ $$ ### tensor - + Return the tensor product with another SparsePauliOp. **Parameters** @@ -784,7 +784,7 @@ $$ ### to\_list - + 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. @@ -804,7 +804,7 @@ $$ ### to\_matrix - + Convert to a dense or sparse matrix. **Parameters** @@ -823,7 +823,7 @@ $$ ### to\_operator - + Convert to a matrix Operator object **Return type** @@ -833,7 +833,7 @@ $$ ### transpose - + Return the transpose of the SparsePauliOp. diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.StabilizerState.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.StabilizerState.mdx index 417202eba8e..e923075c1e9 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.StabilizerState.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.StabilizerState.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.StabilizerState # StabilizerState - + 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"). @@ -83,25 +83,25 @@ python_api_name: qiskit.quantum_info.StabilizerState ### conjugate - + Return the conjugate of the operator. ### copy - + Make a copy of current operator. ### dims - + Return tuple of input dimension for specified subsystems. ### equiv - + Return True if the two generating sets generate the same stabilizer group. **Parameters** @@ -119,7 +119,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### evolve - + Evolve a stabilizer state by a Clifford operator. **Parameters** @@ -143,7 +143,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### expand - + Return the tensor product stabilizer state other ⊗ self. **Parameters** @@ -165,7 +165,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### expectation\_value - + Compute the expectation value of a Pauli operator. **Parameters** @@ -188,7 +188,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### from\_stabilizer\_list - + Create a stabilizer state from the collection of stabilizers. **Parameters** @@ -208,13 +208,13 @@ python_api_name: qiskit.quantum_info.StabilizerState ### is\_valid - + Return True if a valid StabilizerState. ### measure - + 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. @@ -236,7 +236,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### probabilities - + Return the subsystem measurement probability vector. Measurement probabilities are with respect to measurement in the computation (diagonal) basis. @@ -257,7 +257,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### probabilities\_dict - + Return the subsystem measurement probability dictionary. Measurement probabilities are with respect to measurement in the computation (diagonal) basis. @@ -271,16 +271,40 @@ python_api_name: qiskit.quantum_info.StabilizerState **Returns** - The measurement probabilities in dict (ket) form. + The measurement probabilities in dict (key) form. **Return type** [dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + ### probabilities\_dict\_from\_bitstring + + + Return the subsystem measurement probability dictionary utilizing a targeted outcome\_bitstring to perform the measurement for. This will calculate a probability for only a single targeted outcome\_bitstring value, giving a performance boost over calculating all possible outcomes. + + 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** + + * **outcome\_bitstring** (*None or* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – targeted outcome bitstring to perform a measurement calculation for, this will significantly reduce the number of calculation performed (Default: None) + * **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)")\[[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)")] + + ### purity - + Return the purity of the quantum state, which equals to 1, since it is always a pure state. **Returns** @@ -298,7 +322,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### reset - + Reset state or subsystems to the 0-state. **Parameters** @@ -320,7 +344,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### sample\_counts - + Sample a dict of qubit measurement outcomes in the computational basis. **Parameters** @@ -345,7 +369,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### sample\_memory - + Sample a list of qubit measurement outcomes in the computational basis. **Parameters** @@ -370,13 +394,13 @@ python_api_name: qiskit.quantum_info.StabilizerState ### seed - + Set the seed for the quantum state RNG. ### tensor - + Return the tensor product stabilizer state self ⊗ other. **Parameters** @@ -398,7 +422,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### to\_operator - + Convert state to matrix operator class **Return type** @@ -408,7 +432,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### trace - + Return the trace of the stabilizer state as a density matrix, which equals to 1, since it is always a pure state. **Returns** diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.Statevector.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.Statevector.mdx index 13ad4cdfaec..664271d558b 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.Statevector.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.Statevector.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Statevector # Statevector - + Bases: `QuantumState`, `TolerancesMixin` Statevector class @@ -69,7 +69,7 @@ python_api_name: qiskit.quantum_info.Statevector ### conjugate - + Return the conjugate of the operator. **Return type** @@ -79,19 +79,19 @@ python_api_name: qiskit.quantum_info.Statevector ### copy - + Make a copy of current operator. ### dims - + Return tuple of input dimension for specified subsystems. ### draw - + Return a visualization of the Statevector. **repr**: ASCII TextMatrix of the state’s `__repr__`. @@ -141,7 +141,7 @@ python_api_name: qiskit.quantum_info.Statevector ### equiv - + Return True if other is equivalent as a statevector up to global phase. @@ -165,7 +165,7 @@ python_api_name: qiskit.quantum_info.Statevector ### evolve - + Evolve a quantum state by the operator. **Parameters** @@ -188,7 +188,7 @@ python_api_name: qiskit.quantum_info.Statevector ### expand - + Return the tensor product state other ⊗ self. **Parameters** @@ -210,7 +210,7 @@ python_api_name: qiskit.quantum_info.Statevector ### expectation\_value - + Compute the expectation value of an operator. **Parameters** @@ -229,7 +229,7 @@ python_api_name: qiskit.quantum_info.Statevector ### from\_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. @@ -253,7 +253,7 @@ python_api_name: qiskit.quantum_info.Statevector ### from\_int - + Return a computational basis statevector. **Parameters** @@ -279,7 +279,7 @@ python_api_name: qiskit.quantum_info.Statevector ### from\_label - + Return a tensor product of Pauli X,Y,Z eigenstates. | Label | Statevector | @@ -310,7 +310,7 @@ python_api_name: qiskit.quantum_info.Statevector ### inner - + Return the inner product of self and other as $\langle self| other \rangle$. **Parameters** @@ -332,7 +332,7 @@ python_api_name: qiskit.quantum_info.Statevector ### is\_valid - + Return True if a Statevector has norm 1. **Return type** @@ -342,7 +342,7 @@ python_api_name: qiskit.quantum_info.Statevector ### measure - + 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. @@ -364,7 +364,7 @@ python_api_name: qiskit.quantum_info.Statevector ### probabilities - + Return the subsystem measurement probability vector. Measurement probabilities are with respect to measurement in the computation (diagonal) basis. @@ -435,7 +435,7 @@ python_api_name: qiskit.quantum_info.Statevector ### probabilities\_dict - + Return the subsystem measurement probability dictionary. Measurement probabilities are with respect to measurement in the computation (diagonal) basis. @@ -458,7 +458,7 @@ python_api_name: qiskit.quantum_info.Statevector ### purity - + Return the purity of the quantum state. **Return type** @@ -468,7 +468,7 @@ python_api_name: qiskit.quantum_info.Statevector ### reset - + Reset state or subsystems to the 0-state. **Parameters** @@ -490,7 +490,7 @@ python_api_name: qiskit.quantum_info.Statevector ### 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$. @@ -506,7 +506,7 @@ python_api_name: qiskit.quantum_info.Statevector ### sample\_counts - + Sample a dict of qubit measurement outcomes in the computational basis. **Parameters** @@ -531,7 +531,7 @@ python_api_name: qiskit.quantum_info.Statevector ### sample\_memory - + Sample a list of qubit measurement outcomes in the computational basis. **Parameters** @@ -556,13 +556,13 @@ python_api_name: qiskit.quantum_info.Statevector ### seed - + Set the seed for the quantum state RNG. ### tensor - + Return the tensor product state self ⊗ other. **Parameters** @@ -584,7 +584,7 @@ python_api_name: qiskit.quantum_info.Statevector ### to\_dict - + 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. @@ -653,7 +653,7 @@ python_api_name: qiskit.quantum_info.Statevector ### to\_operator - + Convert state to a rank-1 projector operator **Return type** @@ -663,7 +663,7 @@ python_api_name: qiskit.quantum_info.Statevector ### trace - + Return the trace of the quantum state as a density matrix. **Return type** diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.Stinespring.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.Stinespring.mdx index d93651f1073..ef6c3dd8c6b 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.Stinespring.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.Stinespring.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Stinespring # Stinespring - + Bases: `QuantumChannel` Stinespring representation of a quantum channel. @@ -91,7 +91,7 @@ $$ ### adjoint - + Return the adjoint quantum channel. @@ -105,7 +105,7 @@ $$ ### compose - + Return the operator composition with another Stinespring. **Parameters** @@ -135,7 +135,7 @@ $$ ### conjugate - + Return the conjugate quantum channel. @@ -145,13 +145,13 @@ $$ ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -174,7 +174,7 @@ $$ ### expand - + Return the reverse-order tensor product with another Stinespring. **Parameters** @@ -194,13 +194,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_cp - + Test if Choi-matrix is completely-positive (CP) **Return type** @@ -210,13 +210,13 @@ $$ ### is\_cptp - + Return True if completely-positive trace-preserving. ### is\_tp - + Test if a channel is trace-preserving (TP) **Return type** @@ -226,7 +226,7 @@ $$ ### is\_unitary - + Return True if QuantumChannel is a unitary channel. **Return type** @@ -236,13 +236,13 @@ $$ ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the power of the quantum channel. **Parameters** @@ -268,7 +268,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -292,7 +292,7 @@ $$ ### tensor - + Return the tensor product with another Stinespring. **Parameters** @@ -316,7 +316,7 @@ $$ ### 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. @@ -336,7 +336,7 @@ $$ ### to\_operator - + Try to convert channel to a unitary representation Operator. **Return type** @@ -346,7 +346,7 @@ $$ ### transpose - + Return the transpose quantum channel. diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.SuperOp.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.SuperOp.mdx index 1b8ff9550ee..6b79b24453f 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.SuperOp.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.SuperOp.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.SuperOp # SuperOp - + Bases: `QuantumChannel` Superoperator representation of a quantum channel. @@ -87,7 +87,7 @@ $$ ### adjoint - + Return the adjoint quantum channel. @@ -97,7 +97,7 @@ $$ ### compose - + Return the operator composition with another SuperOp. **Parameters** @@ -127,7 +127,7 @@ $$ ### conjugate - + Return the conjugate quantum channel. @@ -137,13 +137,13 @@ $$ ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -166,7 +166,7 @@ $$ ### expand - + Return the reverse-order tensor product with another SuperOp. **Parameters** @@ -186,13 +186,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_cp - + Test if Choi-matrix is completely-positive (CP) **Return type** @@ -202,7 +202,7 @@ $$ ### is\_cptp - + Return True if completely-positive trace-preserving (CPTP). **Return type** @@ -212,7 +212,7 @@ $$ ### is\_tp - + Test if a channel is trace-preserving (TP) **Return type** @@ -222,7 +222,7 @@ $$ ### is\_unitary - + Return True if QuantumChannel is a unitary channel. **Return type** @@ -232,13 +232,13 @@ $$ ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the power of the quantum channel. **Parameters** @@ -264,7 +264,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -288,7 +288,7 @@ $$ ### tensor - + Return the tensor product with another SuperOp. **Parameters** @@ -312,7 +312,7 @@ $$ ### 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. @@ -332,7 +332,7 @@ $$ ### to\_operator - + Try to convert channel to a unitary representation Operator. **Return type** @@ -342,7 +342,7 @@ $$ ### transpose - + Return the transpose quantum channel. diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.Z2Symmetries.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.Z2Symmetries.mdx index e79a45a4cd7..5de50d7f882 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.Z2Symmetries.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.Z2Symmetries.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Z2Symmetries # Z2Symmetries - + 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. @@ -93,7 +93,7 @@ python_api_name: qiskit.quantum_info.Z2Symmetries ### convert\_clifford - + 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** @@ -111,7 +111,7 @@ python_api_name: qiskit.quantum_info.Z2Symmetries ### find\_z2\_symmetries - + Finds Z2 Pauli-type symmetries of a [`SparsePauliOp`](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp"). **Returns** @@ -125,7 +125,7 @@ python_api_name: qiskit.quantum_info.Z2Symmetries ### is\_empty - + Check the z2\_symmetries is empty or not. **Returns** @@ -139,7 +139,7 @@ python_api_name: qiskit.quantum_info.Z2Symmetries ### taper - + 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. @@ -161,7 +161,7 @@ python_api_name: qiskit.quantum_info.Z2Symmetries ### taper\_clifford - + 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** diff --git a/docs/api/qiskit/dev/qiskit.quantum_info.pauli_basis.mdx b/docs/api/qiskit/dev/qiskit.quantum_info.pauli_basis.mdx index 4bd67aea546..013531a21e6 100644 --- a/docs/api/qiskit/dev/qiskit.quantum_info.pauli_basis.mdx +++ b/docs/api/qiskit/dev/qiskit.quantum_info.pauli_basis.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.quantum_info.pauli_basis # qiskit.quantum\_info.pauli\_basis - + Return the ordered PauliList for the n-qubit Pauli basis. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.result.BaseReadoutMitigator.mdx b/docs/api/qiskit/dev/qiskit.result.BaseReadoutMitigator.mdx index f00677bee60..f07705a2b56 100644 --- a/docs/api/qiskit/dev/qiskit.result.BaseReadoutMitigator.mdx +++ b/docs/api/qiskit/dev/qiskit.result.BaseReadoutMitigator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.result.BaseReadoutMitigator # BaseReadoutMitigator - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Base readout error mitigator class. @@ -17,7 +17,7 @@ python_api_name: qiskit.result.BaseReadoutMitigator ### expectation\_value - + Calculate the expectation value of a diagonal Hermitian operator. **Parameters** @@ -39,7 +39,7 @@ python_api_name: qiskit.result.BaseReadoutMitigator ### quasi\_probabilities - + Convert counts to a dictionary of quasi-probabilities **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.result.CorrelatedReadoutMitigator.mdx b/docs/api/qiskit/dev/qiskit.result.CorrelatedReadoutMitigator.mdx index 2f78e29df5e..2435e9b8a4a 100644 --- a/docs/api/qiskit/dev/qiskit.result.CorrelatedReadoutMitigator.mdx +++ b/docs/api/qiskit/dev/qiskit.result.CorrelatedReadoutMitigator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.result.CorrelatedReadoutMitigator # CorrelatedReadoutMitigator - + Bases: [`BaseReadoutMitigator`](qiskit.result.BaseReadoutMitigator "qiskit.result.mitigation.base_readout_mitigator.BaseReadoutMitigator") N-qubit readout error mitigator. @@ -44,7 +44,7 @@ python_api_name: qiskit.result.CorrelatedReadoutMitigator ### assignment\_matrix - + 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$. @@ -64,7 +64,7 @@ python_api_name: qiskit.result.CorrelatedReadoutMitigator ### expectation\_value - + 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|$. @@ -92,7 +92,7 @@ python_api_name: qiskit.result.CorrelatedReadoutMitigator ### mitigation\_matrix - + 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$. @@ -112,7 +112,7 @@ python_api_name: qiskit.result.CorrelatedReadoutMitigator ### quasi\_probabilities - + Compute mitigated quasi probabilities value. **Parameters** @@ -135,7 +135,7 @@ python_api_name: qiskit.result.CorrelatedReadoutMitigator ### stddev\_upper\_bound - + Return an upper bound on standard deviation of expval estimator. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.result.Counts.mdx b/docs/api/qiskit/dev/qiskit.result.Counts.mdx index 75f527cf990..4ade599bcdd 100644 --- a/docs/api/qiskit/dev/qiskit.result.Counts.mdx +++ b/docs/api/qiskit/dev/qiskit.result.Counts.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.result.Counts # Counts - + 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. @@ -67,7 +67,7 @@ python_api_name: qiskit.result.Counts ### hex\_outcomes - + Return a counts dictionary with hexadecimal string keys **Returns** @@ -87,7 +87,7 @@ python_api_name: qiskit.result.Counts ### int\_outcomes - + Build a counts dictionary with integer keys instead of count strings **Returns** @@ -113,7 +113,7 @@ python_api_name: qiskit.result.Counts ### most\_frequent - + Return the most frequent count **Returns** @@ -153,7 +153,7 @@ python_api_name: qiskit.result.Counts ### shots - + Return the number of shots diff --git a/docs/api/qiskit/dev/qiskit.result.LocalReadoutMitigator.mdx b/docs/api/qiskit/dev/qiskit.result.LocalReadoutMitigator.mdx index 8612ab6a2c0..469bc0466e1 100644 --- a/docs/api/qiskit/dev/qiskit.result.LocalReadoutMitigator.mdx +++ b/docs/api/qiskit/dev/qiskit.result.LocalReadoutMitigator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.result.LocalReadoutMitigator # LocalReadoutMitigator - + Bases: [`BaseReadoutMitigator`](qiskit.result.BaseReadoutMitigator "qiskit.result.mitigation.base_readout_mitigator.BaseReadoutMitigator") 1-qubit tensor product readout error mitigator. @@ -45,7 +45,7 @@ python_api_name: qiskit.result.LocalReadoutMitigator ### assignment\_matrix - + 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$. @@ -65,7 +65,7 @@ python_api_name: qiskit.result.LocalReadoutMitigator ### expectation\_value - + 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|$. @@ -93,7 +93,7 @@ python_api_name: qiskit.result.LocalReadoutMitigator ### mitigation\_matrix - + 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$. @@ -113,7 +113,7 @@ python_api_name: qiskit.result.LocalReadoutMitigator ### quasi\_probabilities - + Compute mitigated quasi probabilities value. **Parameters** @@ -140,7 +140,7 @@ python_api_name: qiskit.result.LocalReadoutMitigator ### stddev\_upper\_bound - + Return an upper bound on standard deviation of expval estimator. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.result.ProbDistribution.mdx b/docs/api/qiskit/dev/qiskit.result.ProbDistribution.mdx index def435e1c47..74804d486a7 100644 --- a/docs/api/qiskit/dev/qiskit.result.ProbDistribution.mdx +++ b/docs/api/qiskit/dev/qiskit.result.ProbDistribution.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.result.ProbDistribution # ProbDistribution - + Bases: [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") A generic dict-like class for probability distributions. @@ -36,7 +36,7 @@ python_api_name: qiskit.result.ProbDistribution ### binary\_probabilities - + Build a probabilities dictionary with binary string keys **Parameters** @@ -76,7 +76,7 @@ python_api_name: qiskit.result.ProbDistribution ### hex\_probabilities - + Build a probabilities dictionary with hexadecimal string keys **Returns** diff --git a/docs/api/qiskit/dev/qiskit.result.QuasiDistribution.mdx b/docs/api/qiskit/dev/qiskit.result.QuasiDistribution.mdx index d6549cd0d53..05c79b5552a 100644 --- a/docs/api/qiskit/dev/qiskit.result.QuasiDistribution.mdx +++ b/docs/api/qiskit/dev/qiskit.result.QuasiDistribution.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.result.QuasiDistribution # QuasiDistribution - + Bases: [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") A dict-like class for representing quasi-probabilities. @@ -50,7 +50,7 @@ python_api_name: qiskit.result.QuasiDistribution ### binary\_probabilities - + Build a quasi-probabilities dictionary with binary string keys **Parameters** @@ -90,7 +90,7 @@ python_api_name: qiskit.result.QuasiDistribution ### hex\_probabilities - + Build a quasi-probabilities dictionary with hexadecimal string keys **Returns** @@ -114,7 +114,7 @@ python_api_name: qiskit.result.QuasiDistribution ### nearest\_probability\_distribution - + Takes a quasiprobability distribution and maps it to the closest probability distribution as defined by the L2-norm. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.result.Result.mdx b/docs/api/qiskit/dev/qiskit.result.Result.mdx index 7d791f1bb04..e3abccc8e0e 100644 --- a/docs/api/qiskit/dev/qiskit.result.Result.mdx +++ b/docs/api/qiskit/dev/qiskit.result.Result.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.result.Result # Result - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Model for Results. @@ -77,7 +77,7 @@ python_api_name: qiskit.result.Result ### data - + 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. @@ -109,7 +109,7 @@ python_api_name: qiskit.result.Result ### from\_dict - + Create a new ExperimentResultData object from a dictionary. **Parameters** @@ -127,7 +127,7 @@ python_api_name: qiskit.result.Result ### get\_counts - + Get the histogram data of an experiment. **Parameters** @@ -149,7 +149,7 @@ python_api_name: qiskit.result.Result ### get\_memory - + 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** @@ -179,7 +179,7 @@ python_api_name: qiskit.result.Result ### get\_statevector - + Get the final statevector of an experiment. **Parameters** @@ -202,7 +202,7 @@ python_api_name: qiskit.result.Result ### get\_unitary - + Get the final unitary of an experiment. **Parameters** @@ -227,7 +227,7 @@ python_api_name: qiskit.result.Result ### to\_dict - + Return a dictionary format representation of the Result **Returns** diff --git a/docs/api/qiskit/dev/qiskit.result.ResultError.mdx b/docs/api/qiskit/dev/qiskit.result.ResultError.mdx index edff40fcbb0..c2609d951ad 100644 --- a/docs/api/qiskit/dev/qiskit.result.ResultError.mdx +++ b/docs/api/qiskit/dev/qiskit.result.ResultError.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.result.ResultError # qiskit.result.ResultError - + Exceptions raised due to errors in result output. It may be better for the Qiskit API to raise this exception. diff --git a/docs/api/qiskit/dev/qiskit.synthesis.EvolutionSynthesis.mdx b/docs/api/qiskit/dev/qiskit.synthesis.EvolutionSynthesis.mdx index d650507e1ef..e4c9fb8745d 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.EvolutionSynthesis.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.EvolutionSynthesis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.EvolutionSynthesis # EvolutionSynthesis - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Interface for evolution synthesis algorithms. @@ -33,7 +33,7 @@ python_api_name: qiskit.synthesis.EvolutionSynthesis ### synthesize - + Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.synthesis.LieTrotter.mdx b/docs/api/qiskit/dev/qiskit.synthesis.LieTrotter.mdx index aed4d171297..991d370f335 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.LieTrotter.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.LieTrotter.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.LieTrotter # LieTrotter - + Bases: [`ProductFormula`](qiskit.synthesis.ProductFormula "qiskit.synthesis.evolution.product_formula.ProductFormula") The Lie-Trotter product formula. @@ -56,7 +56,7 @@ $$ ### synthesize - + Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.synthesis.MatrixExponential.mdx b/docs/api/qiskit/dev/qiskit.synthesis.MatrixExponential.mdx index 61785d90f6b..0c38d6fb97d 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.MatrixExponential.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.MatrixExponential.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.MatrixExponential # MatrixExponential - + Bases: [`EvolutionSynthesis`](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.evolution.evolution_synthesis.EvolutionSynthesis") Exact operator evolution via matrix exponentiation and unitary synthesis. @@ -35,7 +35,7 @@ python_api_name: qiskit.synthesis.MatrixExponential ### synthesize - + Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.synthesis.OneQubitEulerDecomposer.mdx b/docs/api/qiskit/dev/qiskit.synthesis.OneQubitEulerDecomposer.mdx index 3bec1535fac..ebeaf08e51b 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.OneQubitEulerDecomposer.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.OneQubitEulerDecomposer.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.OneQubitEulerDecomposer # OneQubitEulerDecomposer - + 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. @@ -32,7 +32,7 @@ python_api_name: qiskit.synthesis.OneQubitEulerDecomposer ### \_\_call\_\_ - + Decompose single qubit gate into a circuit. **Parameters** @@ -79,7 +79,7 @@ python_api_name: qiskit.synthesis.OneQubitEulerDecomposer ### angles - + Return the Euler angles for input array. **Parameters** @@ -97,7 +97,7 @@ python_api_name: qiskit.synthesis.OneQubitEulerDecomposer ### angles\_and\_phase - + Return the Euler angles and phase for input array. **Parameters** @@ -115,7 +115,7 @@ python_api_name: qiskit.synthesis.OneQubitEulerDecomposer ### build\_circuit - + Return the circuit or dag object from a list of gates. diff --git a/docs/api/qiskit/dev/qiskit.synthesis.ProductFormula.mdx b/docs/api/qiskit/dev/qiskit.synthesis.ProductFormula.mdx index c6426af02b5..1fdaeb92727 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.ProductFormula.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.ProductFormula.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.ProductFormula # ProductFormula - + Bases: [`EvolutionSynthesis`](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.evolution.evolution_synthesis.EvolutionSynthesis") Product formula base class for the decomposition of non-commuting operator exponentials. @@ -43,7 +43,7 @@ python_api_name: qiskit.synthesis.ProductFormula ### synthesize - + Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.synthesis.QDrift.mdx b/docs/api/qiskit/dev/qiskit.synthesis.QDrift.mdx index 965bc02d35d..53eb85513b4 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.QDrift.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.QDrift.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.QDrift # QDrift - + 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]. @@ -45,7 +45,7 @@ python_api_name: qiskit.synthesis.QDrift ### synthesize - + Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.synthesis.SolovayKitaevDecomposition.mdx b/docs/api/qiskit/dev/qiskit.synthesis.SolovayKitaevDecomposition.mdx index 6d8cae9778a..fd0590d4e47 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.SolovayKitaevDecomposition.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.SolovayKitaevDecomposition.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.SolovayKitaevDecomposition # SolovayKitaevDecomposition - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") The Solovay Kitaev discrete decomposition algorithm. @@ -23,7 +23,7 @@ python_api_name: qiskit.synthesis.SolovayKitaevDecomposition ### find\_basic\_approximation - + Finds gate in `self._basic_approximations` that best represents `sequence`. **Parameters** @@ -41,7 +41,7 @@ python_api_name: qiskit.synthesis.SolovayKitaevDecomposition ### load\_basic\_approximations - + Load basic approximations. **Parameters** @@ -63,7 +63,7 @@ python_api_name: qiskit.synthesis.SolovayKitaevDecomposition ### run - + Run the algorithm. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.synthesis.SuzukiTrotter.mdx b/docs/api/qiskit/dev/qiskit.synthesis.SuzukiTrotter.mdx index d72b141ff7c..75fa21e218f 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.SuzukiTrotter.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.SuzukiTrotter.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.SuzukiTrotter # SuzukiTrotter - + Bases: [`ProductFormula`](qiskit.synthesis.ProductFormula "qiskit.synthesis.evolution.product_formula.ProductFormula") The (higher order) Suzuki-Trotter product formula. @@ -63,7 +63,7 @@ $$ ### synthesize - + Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.synthesis.TwoQubitBasisDecomposer.mdx b/docs/api/qiskit/dev/qiskit.synthesis.TwoQubitBasisDecomposer.mdx index a43a290173b..66bd395c363 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.TwoQubitBasisDecomposer.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.TwoQubitBasisDecomposer.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.TwoQubitBasisDecomposer # TwoQubitBasisDecomposer - + 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. @@ -22,7 +22,7 @@ python_api_name: qiskit.synthesis.TwoQubitBasisDecomposer ### \_\_call\_\_ - + Decompose a two-qubit `unitary` over fixed basis and $SU(2)$ using the best approximation given that each basis application has a finite `basis_fidelity`. **Parameters** @@ -50,7 +50,7 @@ python_api_name: qiskit.synthesis.TwoQubitBasisDecomposer ### decomp0 - + Decompose target $\sim U_d(x, y, z)$ with $0$ uses of the basis gate. Result $U_r$ has trace: $$ @@ -63,7 +63,7 @@ $$ ### decomp1 - + Decompose target $\sim U_d(x, y, z)$ with $1$ use of the basis gate $\sim U_d(a, b, c)$. Result $U_r$ has trace: $$ @@ -76,7 +76,7 @@ $$ ### decomp2\_supercontrolled - + Decompose target $\sim U_d(x, y, z)$ with $2$ uses of the basis gate. For supercontrolled basis $\sim U_d(\pi/4, b, 0)$, all b, result $U_r$ has trace @@ -90,19 +90,19 @@ $$ ### decomp3\_supercontrolled - + Decompose target with $3$ uses of the basis. This is an exact decomposition for supercontrolled basis $\sim U_d(\pi/4, b, 0)$, all b, and any target. No guarantees for non-supercontrolled basis. ### num\_basis\_gates - + Computes the number of basis gates needed in a decomposition of input unitary ### traces - + Give the expected traces $\Big\vert\text{Tr}(U \cdot U_\text{target}^{\dag})\Big\vert$ for a different number of basis gates. diff --git a/docs/api/qiskit/dev/qiskit.synthesis.TwoQubitWeylDecomposition.mdx b/docs/api/qiskit/dev/qiskit.synthesis.TwoQubitWeylDecomposition.mdx index b7a76e0d36b..d9391380b57 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.TwoQubitWeylDecomposition.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.TwoQubitWeylDecomposition.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.TwoQubitWeylDecomposition # TwoQubitWeylDecomposition - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Two-qubit Weyl decomposition. @@ -90,7 +90,7 @@ $$ ### actual\_fidelity - + Calculates the actual fidelity of the decomposed circuit to the input unitary. **Return type** @@ -100,7 +100,7 @@ $$ ### circuit - + Returns Weyl decomposition in circuit form. **Return type** @@ -110,7 +110,7 @@ $$ ### from\_bytes - + Decode bytes into [`TwoQubitWeylDecomposition`](#qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.TwoQubitWeylDecomposition"). **Return type** @@ -120,7 +120,7 @@ $$ ### specialize - + Make changes to the decomposition to comply with any specializations. This method will always raise a `NotImplementedError` because there are no specializations to comply with in the current implementation. diff --git a/docs/api/qiskit/dev/qiskit.synthesis.XXDecomposer.mdx b/docs/api/qiskit/dev/qiskit.synthesis.XXDecomposer.mdx index 86a352a60b3..e260c87f0ef 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.XXDecomposer.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.XXDecomposer.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.XXDecomposer # XXDecomposer - + 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$). @@ -26,7 +26,7 @@ python_api_name: qiskit.synthesis.XXDecomposer ### \_\_call\_\_ - + Fashions a circuit which (perhaps approximately) models the special unitary operation `unitary`, using the circuit templates supplied at initialization as `embodiments`. The routine uses `basis_fidelity` to select the optimal circuit template, including when performing exact synthesis; the contents of `basis_fidelity` is a dictionary mapping interaction strengths (scaled so that $CX = RZX(\pi/2)$ corresponds to $\pi/2$) to circuit fidelities. **Parameters** @@ -49,7 +49,7 @@ python_api_name: qiskit.synthesis.XXDecomposer ### num\_basis\_gates - + Counts the number of gates that would be emitted during re-synthesis. diff --git a/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.AQC.mdx b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.AQC.mdx index 552307e10c9..7a7139f4dd4 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.AQC.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.AQC.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.AQC # AQC - + 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: @@ -27,7 +27,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.AQC ### compile\_unitary - + 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** diff --git a/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.ApproximateCircuit.mdx b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.ApproximateCircuit.mdx index 7eb71bba9ff..226682cc96d 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.ApproximateCircuit.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.ApproximateCircuit.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit # ApproximateCircuit - + 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. @@ -23,7 +23,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -37,13 +37,13 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -57,7 +57,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -77,9 +77,9 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -219,7 +219,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### thetas @@ -232,11 +232,41 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit a vector of parameters of this circuit. + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.synthesis.unitary.aqc.ApproximateCircuit.unit "qiskit.synthesis.unitary.aqc.ApproximateCircuit.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.synthesis.unitary.aqc.ApproximateCircuit.duration "qiskit.synthesis.unitary.aqc.ApproximateCircuit.duration") is specified in. + + ## Methods ### build - + **Constructs this circuit out of the parameters(thetas). Parameter values must be set before** constructing the circuit. diff --git a/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.ApproximatingObjective.mdx b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.ApproximatingObjective.mdx index 5dc0fb0c764..2f9e48c7681 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.ApproximatingObjective.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.ApproximatingObjective.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximatingObjective # ApproximatingObjective - + 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. @@ -31,7 +31,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximatingObjective ### gradient - + Computes a gradient with respect to parameters given a vector of parameter values. **Parameters** @@ -49,7 +49,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximatingObjective ### objective - + Computes a value of the objective function given a vector of parameter values. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.mdx b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.mdx index bca25f48d93..7647c327fac 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit # CNOTUnitCircuit - + 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. @@ -29,7 +29,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -43,13 +43,13 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -63,7 +63,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances @@ -83,9 +83,9 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -225,7 +225,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### thetas @@ -238,11 +238,41 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit Parameters of the rotation gates in this circuit. + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.unit "qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.duration "qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.duration") is specified in. + + ## Methods ### build - + **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/dev/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.mdx b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.mdx index 34c2e1b7d15..70078961e1c 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitObjective # CNOTUnitObjective - + 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. diff --git a/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.mdx b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.mdx index d348762b6f1..13f686b4e95 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective # DefaultCNOTUnitObjective - + 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. @@ -42,7 +42,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective ### gradient - + Computes a gradient with respect to parameters given a vector of parameter values. **Parameters** @@ -60,7 +60,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective ### objective - + Computes a value of the objective function given a vector of parameter values. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.mdx b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.mdx index 4df9e2acf1f..47520441bea 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective # FastCNOTUnitObjective - + 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. @@ -42,7 +42,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective ### gradient - + Computes the gradient of objective function. See description of the base class method. **Return type** @@ -52,7 +52,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective ### objective - + Computes the objective function and some intermediate data for the subsequent gradient computation. See description of the base class method. **Return type** diff --git a/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.mdx b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.mdx index dd3162bb2ba..b2d563b215f 100644 --- a/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.mdx +++ b/docs/api/qiskit/dev/qiskit.synthesis.unitary.aqc.mdx @@ -127,7 +127,7 @@ This uses a helper function, [`make_cnot_network`](#qiskit.synthesis.unitary.aqc ### make\_cnot\_network - + 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** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.AnalysisPass.mdx b/docs/api/qiskit/dev/qiskit.transpiler.AnalysisPass.mdx index d8124491968..31fb4be9e49 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.AnalysisPass.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.AnalysisPass.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.AnalysisPass # AnalysisPass - + Bases: `BasePass` An analysis pass: change property set, not DAG. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.AnalysisPass ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.AnalysisPass ### name - + Name of the pass. **Return type** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.AnalysisPass ### run - + Run a pass on the DAGCircuit. This is implemented by the pass developer. **Parameters** @@ -79,7 +79,7 @@ python_api_name: qiskit.transpiler.AnalysisPass ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.CouplingMap.mdx b/docs/api/qiskit/dev/qiskit.transpiler.CouplingMap.mdx index fa6581e7449..33be12bcfc1 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.CouplingMap.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.CouplingMap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.CouplingMap # CouplingMap - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Directed graph specifying fixed coupling. @@ -58,7 +58,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### add\_edge - + Add directed edge to coupling graph. src (int): source physical qubit dst (int): destination physical qubit @@ -66,7 +66,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### add\_physical\_qubit - + Add a physical qubit to the coupling graph as a node. physical\_qubit (int): An integer representing a physical qubit. @@ -78,7 +78,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### 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. @@ -86,7 +86,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### 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: @@ -142,7 +142,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### distance - + Returns the undirected distance between physical\_qubit1 and physical\_qubit2. **Parameters** @@ -165,7 +165,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### 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)") function from the `rustworkx` package to draw the [`CouplingMap`](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object. @@ -181,7 +181,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### from\_full - + Return a fully connected coupling map on n qubits. **Return type** @@ -191,7 +191,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### from\_grid - + Return a coupling map of qubits connected on a grid of num\_rows x num\_columns. **Return type** @@ -201,7 +201,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### from\_heavy\_hex - + Return a heavy hexagon graph coupling map. A heavy hexagon graph is described in: @@ -224,7 +224,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### from\_heavy\_square - + Return a heavy square graph coupling map. A heavy square graph is described in: @@ -247,7 +247,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### from\_hexagonal\_lattice - + Return a hexagonal lattice graph coupling map. **Parameters** @@ -267,7 +267,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### from\_line - + Return a coupling map of n qubits connected in a line. **Return type** @@ -277,7 +277,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### from\_ring - + Return a coupling map of n qubits connected to each of their neighbors in a ring. **Return type** @@ -287,7 +287,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### get\_edges - + Gets the list of edges in the coupling graph. **Returns** @@ -301,7 +301,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### is\_connected - + Test if the graph is connected. Return True if connected, False otherwise @@ -309,19 +309,19 @@ python_api_name: qiskit.transpiler.CouplingMap ### largest\_connected\_component - + Return a set of qubits in the largest connected component. ### make\_symmetric - + Convert uni-directional edges into bi-directional. ### neighbors - + 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. @@ -329,7 +329,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### reduce - + Returns a reduced coupling map that corresponds to the subgraph of qubits selected in the mapping. **Parameters** @@ -352,7 +352,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### shortest\_undirected\_path - + Returns the shortest undirected path between physical\_qubit1 and physical\_qubit2. **Parameters** @@ -375,7 +375,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### size - + Return the number of physical qubits in this graph. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.InstructionDurations.mdx b/docs/api/qiskit/dev/qiskit.transpiler.InstructionDurations.mdx index 577c3e2aa23..aca35a30712 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.InstructionDurations.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.InstructionDurations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.InstructionDurations # InstructionDurations - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Helper class to provide durations of instructions for scheduling. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.InstructionDurations ### from\_backend - + Construct an [`InstructionDurations`](#qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object from the backend. **Parameters** @@ -41,7 +41,7 @@ python_api_name: qiskit.transpiler.InstructionDurations ### get - + Get the duration of the instruction with the name, qubits, and parameters. Some instructions may have a parameter dependent duration. @@ -68,7 +68,7 @@ python_api_name: qiskit.transpiler.InstructionDurations ### units\_used - + Get the set of all units used in this instruction durations. **Returns** @@ -82,7 +82,7 @@ python_api_name: qiskit.transpiler.InstructionDurations ### update - + Update self with inst\_durations (inst\_durations overwrite self). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.InstructionProperties.mdx b/docs/api/qiskit/dev/qiskit.transpiler.InstructionProperties.mdx index 5982dfecf08..6ed7cc5c62f 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.InstructionProperties.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.InstructionProperties.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.InstructionProperties # InstructionProperties - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") A representation of the properties of a gate implementation. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.Layout.mdx b/docs/api/qiskit/dev/qiskit.transpiler.Layout.mdx index af6f13b0545..f637f9b1560 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.Layout.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.Layout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.Layout # Layout - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Two-ways dict to represent a Layout. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.Layout ### add - + 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** @@ -30,7 +30,7 @@ python_api_name: qiskit.transpiler.Layout ### add\_register - + Adds at the end physical\_qubits that map each bit in reg. **Parameters** @@ -40,7 +40,7 @@ python_api_name: qiskit.transpiler.Layout ### combine\_into\_edge\_map - + Combines self and another\_layout into an “edge map”. For example: @@ -73,7 +73,7 @@ python_api_name: qiskit.transpiler.Layout ### compose - + Compose this layout with another layout. If this layout represents a mapping from the P-qubits to the positions of the Q-qubits, and the other layout represents a mapping from the Q-qubits to the positions of the R-qubits, then the composed layout represents a mapping from the P-qubits to the positions of the R-qubits. @@ -94,13 +94,13 @@ python_api_name: qiskit.transpiler.Layout ### copy - + Returns a copy of a Layout instance. ### from\_dict - + Populates a Layout from a dictionary. The dictionary must be a bijective mapping between virtual qubits (tuple) and physical qubits (int). @@ -134,7 +134,7 @@ python_api_name: qiskit.transpiler.Layout ### from\_intlist - + Converts a list of integers to a Layout mapping virtual qubits (index of the list) to physical qubits (the list values). **Parameters** @@ -157,7 +157,7 @@ python_api_name: qiskit.transpiler.Layout ### from\_qubit\_list - + Populates a Layout from a list containing virtual qubits, Qubit or None. **Parameters** @@ -180,7 +180,7 @@ python_api_name: qiskit.transpiler.Layout ### generate\_trivial\_layout - + Creates a trivial (“one-to-one”) Layout with the registers and qubits in regs. **Parameters** @@ -198,25 +198,25 @@ python_api_name: qiskit.transpiler.Layout ### get\_physical\_bits - + Returns the dictionary where the keys are physical (qu)bits and the values are virtual (qu)bits. ### 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 - + Returns the dictionary where the keys are virtual (qu)bits and the values are physical (qu)bits. ### inverse - + Finds the inverse of this layout. This is possible when the layout is a bijective mapping, however the input and the output qubits may be different (in particular, this layout may be the mapping from the extended-with-ancillas virtual qubits to physical qubits). Thus, if this layout represents a mapping from the P-qubits to the positions of the Q-qubits, the inverse layout represents a mapping from the Q-qubits to the positions of the P-qubits. @@ -233,13 +233,13 @@ python_api_name: qiskit.transpiler.Layout ### order\_based\_on\_type - + decides which one is physical/virtual based on the type. Returns (virtual, physical) ### reorder\_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. @@ -259,7 +259,7 @@ python_api_name: qiskit.transpiler.Layout ### swap - + Swaps the map between left and right. **Parameters** @@ -274,7 +274,7 @@ python_api_name: qiskit.transpiler.Layout ### to\_permutation - + Creates a permutation corresponding to this layout. This is possible when the layout is a bijective mapping with the same source and target qubits (for instance, a “final\_layout” corresponds to a permutation of the physical circuit qubits). If this layout is a mapping from qubits to their new positions, the resulting permutation describes which qubits occupy the positions 0, 1, 2, etc. after applying the permutation. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.PassManager.mdx b/docs/api/qiskit/dev/qiskit.transpiler.PassManager.mdx index e4936fc75f8..0f46f83b8e1 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.PassManager.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.PassManager.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.PassManager # PassManager - + Bases: [`BasePassManager`](qiskit.passmanager.BasePassManager "qiskit.passmanager.passmanager.BasePassManager") Manager for a set of Passes and their scheduling during transpilation. @@ -24,7 +24,7 @@ python_api_name: qiskit.transpiler.PassManager ### append - + Append a Pass Set to the schedule of passes. **Parameters** @@ -38,7 +38,7 @@ python_api_name: qiskit.transpiler.PassManager ### draw - + 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. @@ -64,7 +64,7 @@ python_api_name: qiskit.transpiler.PassManager ### remove - + Removes a particular pass in the scheduler. **Parameters** @@ -78,7 +78,7 @@ python_api_name: qiskit.transpiler.PassManager ### replace - + Replace a particular pass in the scheduler. **Parameters** @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.PassManager ### run - + Run all the passes on the specified `circuits`. **Parameters** @@ -141,7 +141,7 @@ python_api_name: qiskit.transpiler.PassManager ### 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** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.PassManagerConfig.mdx b/docs/api/qiskit/dev/qiskit.transpiler.PassManagerConfig.mdx index c2340dadb5d..304987e74a7 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.PassManagerConfig.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.PassManagerConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.PassManagerConfig # PassManagerConfig - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Pass Manager Configuration. @@ -40,7 +40,7 @@ python_api_name: qiskit.transpiler.PassManagerConfig ### from\_backend - + 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. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.StagedPassManager.mdx b/docs/api/qiskit/dev/qiskit.transpiler.StagedPassManager.mdx index 82442a76ff1..b3a67041165 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.StagedPassManager.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.StagedPassManager.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.StagedPassManager # StagedPassManager - + Bases: [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.passmanager.PassManager") A pass manager pipeline built from individual stages. @@ -64,7 +64,7 @@ python_api_name: qiskit.transpiler.StagedPassManager ### append - + Append a Pass Set to the schedule of passes. **Parameters** @@ -78,13 +78,13 @@ python_api_name: qiskit.transpiler.StagedPassManager ### draw - + Draw the staged pass manager. ### remove - + Removes a particular pass in the scheduler. **Parameters** @@ -98,7 +98,7 @@ python_api_name: qiskit.transpiler.StagedPassManager ### replace - + Replace a particular pass in the scheduler. **Parameters** @@ -109,7 +109,7 @@ python_api_name: qiskit.transpiler.StagedPassManager ### run - + Run all the passes on the specified `circuits`. **Parameters** @@ -161,7 +161,7 @@ python_api_name: qiskit.transpiler.StagedPassManager ### 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** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.Target.mdx b/docs/api/qiskit/dev/qiskit.transpiler.Target.mdx index 119547304c0..340447835ec 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.Target.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.Target.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.Target # Target - + 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. @@ -159,7 +159,7 @@ python_api_name: qiskit.transpiler.Target ### add\_instruction - + 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: @@ -198,7 +198,7 @@ python_api_name: qiskit.transpiler.Target ### build\_coupling\_map - + 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. @@ -226,7 +226,7 @@ python_api_name: qiskit.transpiler.Target ### durations - + Get an InstructionDurations object from the target **Returns** @@ -242,7 +242,7 @@ python_api_name: qiskit.transpiler.Target ### from\_configuration - + 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"). @@ -283,7 +283,7 @@ python_api_name: qiskit.transpiler.Target ### get\_calibration - + 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. @@ -306,7 +306,7 @@ python_api_name: qiskit.transpiler.Target ### get\_non\_global\_operation\_names - + 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). @@ -326,7 +326,7 @@ python_api_name: qiskit.transpiler.Target ### has\_calibration - + Return whether the instruction (operation + qubits) defines a calibration. **Parameters** @@ -345,7 +345,7 @@ python_api_name: qiskit.transpiler.Target ### instruction\_properties - + 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: @@ -383,7 +383,7 @@ python_api_name: qiskit.transpiler.Target ### instruction\_schedule\_map - + Return an [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions in the target with a pulse schedule defined. **Returns** @@ -397,7 +397,7 @@ python_api_name: qiskit.transpiler.Target ### instruction\_supported - + Return whether the instruction (operation + qubits) is supported by the target **Parameters** @@ -436,15 +436,15 @@ python_api_name: qiskit.transpiler.Target ### items - + ### keys - + ### operation\_from\_name - + Get the operation class object for a given name **Parameters** @@ -462,7 +462,7 @@ python_api_name: qiskit.transpiler.Target ### operation\_names\_for\_qargs - + Get the operation names for a specified qargs tuple **Parameters** @@ -484,7 +484,7 @@ python_api_name: qiskit.transpiler.Target ### operations\_for\_qargs - + Get the operation class object for a specified qargs tuple **Parameters** @@ -506,7 +506,7 @@ python_api_name: qiskit.transpiler.Target ### qargs\_for\_operation\_name - + Get the qargs for a given operation name **Parameters** @@ -524,7 +524,7 @@ python_api_name: qiskit.transpiler.Target ### timing\_constraints - + Get an `TimingConstraints` object from the target **Returns** @@ -538,7 +538,7 @@ python_api_name: qiskit.transpiler.Target ### update\_from\_instruction\_schedule\_map - + 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. @@ -570,7 +570,7 @@ python_api_name: qiskit.transpiler.Target ### update\_instruction\_properties - + Update the property object for an instruction qarg pair already in the Target **Parameters** @@ -586,6 +586,6 @@ python_api_name: qiskit.transpiler.Target ### values - + diff --git a/docs/api/qiskit/dev/qiskit.transpiler.TransformationPass.mdx b/docs/api/qiskit/dev/qiskit.transpiler.TransformationPass.mdx index bde1bad1fe3..fc582acd637 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.TransformationPass.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.TransformationPass.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.TransformationPass # TransformationPass - + Bases: `BasePass` A transformation pass: change DAG, not property set. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.TransformationPass ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.TransformationPass ### name - + Name of the pass. **Return type** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.TransformationPass ### run - + Run a pass on the DAGCircuit. This is implemented by the pass developer. **Parameters** @@ -79,7 +79,7 @@ python_api_name: qiskit.transpiler.TransformationPass ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.TranspileLayout.mdx b/docs/api/qiskit/dev/qiskit.transpiler.TranspileLayout.mdx index be096e4fe3a..32e3debc641 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.TranspileLayout.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.TranspileLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.TranspileLayout # TranspileLayout - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Layout attributes for the output circuit from transpiler. @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.TranspileLayout ### final\_index\_layout - + Generate the final layout as an array of integers. This method will generate an array of final positions for each qubit in the input circuit. For example, if you had an input circuit like: @@ -110,7 +110,7 @@ python_api_name: qiskit.transpiler.TranspileLayout ### final\_virtual\_layout - + 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 input circuit. For example, if you had an input circuit like: @@ -159,7 +159,7 @@ python_api_name: qiskit.transpiler.TranspileLayout ### initial\_index\_layout - + Generate an initial layout as an array of integers. **Parameters** @@ -177,7 +177,7 @@ python_api_name: qiskit.transpiler.TranspileLayout ### initial\_virtual\_layout - + Return a [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") object for the initial layout. This returns a mapping of virtual [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit") objects in the input circuit to the positions of the physical qubits selected during layout. This is analogous to the [`initial_layout`](#qiskit.transpiler.TranspileLayout.initial_layout "qiskit.transpiler.TranspileLayout.initial_layout") attribute. @@ -197,7 +197,7 @@ python_api_name: qiskit.transpiler.TranspileLayout ### 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]`. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.ALAPSchedule.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.ALAPSchedule.mdx index b9ab449c24f..f44a7087e18 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.ALAPSchedule.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.ALAPSchedule.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ALAPSchedule # ALAPSchedule - + Bases: `BaseSchedulerTransform` ALAP Scheduling pass, which schedules the **stop** time of instructions as late as possible. @@ -45,7 +45,7 @@ python_api_name: qiskit.transpiler.passes.ALAPSchedule ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.ALAPSchedule ### name - + Name of the pass. **Return type** @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.ALAPSchedule ### run - + Run the ALAPSchedule pass on dag. **Parameters** @@ -98,7 +98,7 @@ python_api_name: qiskit.transpiler.passes.ALAPSchedule ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.ALAPScheduleAnalysis.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.ALAPScheduleAnalysis.mdx index 9e66c4bab82..5d37d36dcc0 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.ALAPScheduleAnalysis.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.ALAPScheduleAnalysis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ALAPScheduleAnalysis # ALAPScheduleAnalysis - + Bases: `BaseScheduler` ALAP Scheduling pass, which schedules the **stop** time of instructions as late as possible. @@ -48,7 +48,7 @@ python_api_name: qiskit.transpiler.passes.ALAPScheduleAnalysis ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -68,7 +68,7 @@ python_api_name: qiskit.transpiler.passes.ALAPScheduleAnalysis ### name - + Name of the pass. **Return type** @@ -78,7 +78,7 @@ python_api_name: qiskit.transpiler.passes.ALAPScheduleAnalysis ### run - + Run the ALAPSchedule pass on dag. **Parameters** @@ -101,7 +101,7 @@ python_api_name: qiskit.transpiler.passes.ALAPScheduleAnalysis ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.ASAPSchedule.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.ASAPSchedule.mdx index cc29aa14081..56d116f44f6 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.ASAPSchedule.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.ASAPSchedule.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ASAPSchedule # ASAPSchedule - + Bases: `BaseSchedulerTransform` ASAP Scheduling pass, which schedules the start time of instructions as early as possible.. @@ -49,7 +49,7 @@ python_api_name: qiskit.transpiler.passes.ASAPSchedule ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.ASAPSchedule ### name - + Name of the pass. **Return type** @@ -79,7 +79,7 @@ python_api_name: qiskit.transpiler.passes.ASAPSchedule ### run - + Run the ASAPSchedule pass on dag. **Parameters** @@ -102,7 +102,7 @@ python_api_name: qiskit.transpiler.passes.ASAPSchedule ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.ASAPScheduleAnalysis.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.ASAPScheduleAnalysis.mdx index e1c5fc97db3..6bf69560e5a 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.ASAPScheduleAnalysis.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.ASAPScheduleAnalysis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ASAPScheduleAnalysis # ASAPScheduleAnalysis - + Bases: `BaseScheduler` ASAP Scheduling pass, which schedules the start time of instructions as early as possible. @@ -48,7 +48,7 @@ python_api_name: qiskit.transpiler.passes.ASAPScheduleAnalysis ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -68,7 +68,7 @@ python_api_name: qiskit.transpiler.passes.ASAPScheduleAnalysis ### name - + Name of the pass. **Return type** @@ -78,7 +78,7 @@ python_api_name: qiskit.transpiler.passes.ASAPScheduleAnalysis ### run - + Run the ASAPSchedule pass on dag. **Parameters** @@ -101,7 +101,7 @@ python_api_name: qiskit.transpiler.passes.ASAPScheduleAnalysis ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.AlignMeasures.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.AlignMeasures.mdx index b57d1ceccae..d38f17aad9b 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.AlignMeasures.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.AlignMeasures.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.AlignMeasures # AlignMeasures - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Measurement alignment. @@ -83,7 +83,7 @@ python_api_name: qiskit.transpiler.passes.AlignMeasures ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -103,7 +103,7 @@ python_api_name: qiskit.transpiler.passes.AlignMeasures ### name - + Name of the pass. **Return type** @@ -113,7 +113,7 @@ python_api_name: qiskit.transpiler.passes.AlignMeasures ### run - + Run the measurement alignment pass on dag. **Parameters** @@ -135,7 +135,7 @@ python_api_name: qiskit.transpiler.passes.AlignMeasures ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.ApplyLayout.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.ApplyLayout.mdx index cbe3631b35e..e1377d22fa8 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.ApplyLayout.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.ApplyLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ApplyLayout # ApplyLayout - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Transform a circuit with virtual qubits into a circuit with physical qubits. @@ -39,7 +39,7 @@ python_api_name: qiskit.transpiler.passes.ApplyLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -59,7 +59,7 @@ python_api_name: qiskit.transpiler.passes.ApplyLayout ### name - + Name of the pass. **Return type** @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.ApplyLayout ### run - + Run the ApplyLayout pass on `dag`. **Parameters** @@ -91,7 +91,7 @@ python_api_name: qiskit.transpiler.passes.ApplyLayout ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.mdx index 0df1aa7c530..8462d593311 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.BarrierBeforeFinalMeasurements # BarrierBeforeFinalMeasurements - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Add a barrier before final measurements. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.BarrierBeforeFinalMeasurements ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.BarrierBeforeFinalMeasurements ### name - + Name of the pass. **Return type** @@ -67,13 +67,13 @@ python_api_name: qiskit.transpiler.passes.BarrierBeforeFinalMeasurements ### run - + Run the BarrierBeforeFinalMeasurements pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.BasicSwap.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.BasicSwap.mdx index f273d163f87..3ae0df90dbd 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.BasicSwap.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.BasicSwap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.BasicSwap # BasicSwap - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Map (with minimum effort) a DAGCircuit onto a `coupling_map` adding swap gates. @@ -44,7 +44,7 @@ python_api_name: qiskit.transpiler.passes.BasicSwap ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -64,7 +64,7 @@ python_api_name: qiskit.transpiler.passes.BasicSwap ### name - + Name of the pass. **Return type** @@ -74,7 +74,7 @@ python_api_name: qiskit.transpiler.passes.BasicSwap ### run - + Run the BasicSwap pass on dag. **Parameters** @@ -97,7 +97,7 @@ python_api_name: qiskit.transpiler.passes.BasicSwap ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.BasisTranslator.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.BasisTranslator.mdx index 3b0ec92cc11..197c87faf50 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.BasisTranslator.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.BasisTranslator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.BasisTranslator # BasisTranslator - + 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. @@ -32,7 +32,7 @@ python_api_name: qiskit.transpiler.passes.BasisTranslator 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. + When this error occurs it typically means that either the target basis is not universal or there are additional equivalence rules needed in the [`EquivalenceLibrary`](qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary") instance being used by the [`BasisTranslator`](#qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator") pass. You can refer to [Custom Basis Gates](providers#custom-basis-gates) for details on adding custom equivalence rules. Initialize a BasisTranslator instance. @@ -90,7 +90,7 @@ python_api_name: qiskit.transpiler.passes.BasisTranslator ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -110,7 +110,7 @@ python_api_name: qiskit.transpiler.passes.BasisTranslator ### name - + Name of the pass. **Return type** @@ -120,7 +120,7 @@ python_api_name: qiskit.transpiler.passes.BasisTranslator ### run - + Translate an input DAGCircuit to the target basis. **Parameters** @@ -142,7 +142,7 @@ python_api_name: qiskit.transpiler.passes.BasisTranslator ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.CSPLayout.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.CSPLayout.mdx index 48efc27f5cb..fb646c9c695 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.CSPLayout.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.CSPLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CSPLayout # CSPLayout - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") If possible, chooses a Layout as a CSP, using backtracking. @@ -52,7 +52,7 @@ python_api_name: qiskit.transpiler.passes.CSPLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -72,7 +72,7 @@ python_api_name: qiskit.transpiler.passes.CSPLayout ### name - + Name of the pass. **Return type** @@ -82,13 +82,13 @@ python_api_name: qiskit.transpiler.passes.CSPLayout ### run - + run the layout method ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.CXCancellation.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.CXCancellation.mdx index 62932d98a6c..c05db585a3e 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.CXCancellation.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.CXCancellation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CXCancellation # CXCancellation - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Cancel back-to-back `cx` gates in dag. @@ -39,7 +39,7 @@ python_api_name: qiskit.transpiler.passes.CXCancellation ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -59,7 +59,7 @@ python_api_name: qiskit.transpiler.passes.CXCancellation ### name - + Name of the pass. **Return type** @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.CXCancellation ### run - + Run the CXCancellation pass on dag. **Parameters** @@ -87,7 +87,7 @@ python_api_name: qiskit.transpiler.passes.CXCancellation ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.CheckGateDirection.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.CheckGateDirection.mdx index d9a376a7c79..40d8075135d 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.CheckGateDirection.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.CheckGateDirection.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CheckGateDirection # CheckGateDirection - + 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. @@ -42,7 +42,7 @@ python_api_name: qiskit.transpiler.passes.CheckGateDirection ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -62,7 +62,7 @@ python_api_name: qiskit.transpiler.passes.CheckGateDirection ### name - + Name of the pass. **Return type** @@ -72,7 +72,7 @@ python_api_name: qiskit.transpiler.passes.CheckGateDirection ### run - + 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). @@ -84,7 +84,7 @@ python_api_name: qiskit.transpiler.passes.CheckGateDirection ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.CheckMap.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.CheckMap.mdx index 66529134aa5..7c39cb688d3 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.CheckMap.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.CheckMap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CheckMap # CheckMap - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Check if a DAG circuit is already mapped to a coupling map. @@ -44,7 +44,7 @@ python_api_name: qiskit.transpiler.passes.CheckMap ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -64,7 +64,7 @@ python_api_name: qiskit.transpiler.passes.CheckMap ### name - + Name of the pass. **Return type** @@ -74,7 +74,7 @@ python_api_name: qiskit.transpiler.passes.CheckMap ### run - + 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). @@ -86,7 +86,7 @@ python_api_name: qiskit.transpiler.passes.CheckMap ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.Collect1qRuns.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.Collect1qRuns.mdx index 1389a25035e..f57b5914cd5 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.Collect1qRuns.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.Collect1qRuns.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Collect1qRuns # Collect1qRuns - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Collect one-qubit subcircuits. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.passes.Collect1qRuns ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.Collect1qRuns ### name - + Name of the pass. **Return type** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.Collect1qRuns ### run - + 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. @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.Collect1qRuns ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.Collect2qBlocks.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.Collect2qBlocks.mdx index f366f7fc813..edca6c4a95c 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.Collect2qBlocks.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.Collect2qBlocks.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Collect2qBlocks # Collect2qBlocks - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Collect two-qubit subcircuits. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.passes.Collect2qBlocks ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.Collect2qBlocks ### name - + Name of the pass. **Return type** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.Collect2qBlocks ### run - + 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. @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.Collect2qBlocks ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.CollectCliffords.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.CollectCliffords.mdx index fdf5d92cae2..ad659752d12 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.CollectCliffords.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.CollectCliffords.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CollectCliffords # CollectCliffords - + Bases: `CollectAndCollapse` Collects blocks of Clifford gates and replaces them by a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") object. @@ -45,7 +45,7 @@ python_api_name: qiskit.transpiler.passes.CollectCliffords ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.CollectCliffords ### name - + Name of the pass. **Return type** @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.CollectCliffords ### run - + Run the CollectLinearFunctions pass on dag. :param dag: the DAG to be optimized. :type dag: DAGCircuit **Returns** @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.CollectCliffords ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.CollectLinearFunctions.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.CollectLinearFunctions.mdx index 7113f8eb806..04956321bd7 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.CollectLinearFunctions.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.CollectLinearFunctions.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CollectLinearFunctions # CollectLinearFunctions - + 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")). @@ -45,7 +45,7 @@ python_api_name: qiskit.transpiler.passes.CollectLinearFunctions ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.CollectLinearFunctions ### name - + Name of the pass. **Return type** @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.CollectLinearFunctions ### run - + Run the CollectLinearFunctions pass on dag. :param dag: the DAG to be optimized. :type dag: DAGCircuit **Returns** @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.CollectLinearFunctions ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.CollectMultiQBlocks.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.CollectMultiQBlocks.mdx index b9fe3ce77e5..c0e5294ec86 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.CollectMultiQBlocks.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.CollectMultiQBlocks.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CollectMultiQBlocks # CollectMultiQBlocks - + 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 @@ -45,7 +45,7 @@ python_api_name: qiskit.transpiler.passes.CollectMultiQBlocks ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -65,13 +65,13 @@ python_api_name: qiskit.transpiler.passes.CollectMultiQBlocks ### find\_set - + 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 of the pass. **Return type** @@ -81,7 +81,7 @@ python_api_name: qiskit.transpiler.passes.CollectMultiQBlocks ### run - + 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. @@ -93,13 +93,13 @@ python_api_name: qiskit.transpiler.passes.CollectMultiQBlocks ### union\_set - + 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 workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.CommutationAnalysis.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.CommutationAnalysis.mdx index 078a686b2d8..cbbcfb9cb1b 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.CommutationAnalysis.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.CommutationAnalysis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CommutationAnalysis # CommutationAnalysis - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Analysis pass to find commutation relations between DAG nodes. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.CommutationAnalysis ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.CommutationAnalysis ### name - + Name of the pass. **Return type** @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.CommutationAnalysis ### run - + Run the CommutationAnalysis pass on dag. Run the pass on the DAG, and write the discovered commutation relations into the `property_set`. @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.CommutationAnalysis ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.CommutativeCancellation.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.CommutativeCancellation.mdx index 1065f594b98..434c0c03f50 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.CommutativeCancellation.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.CommutativeCancellation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeCancellation # CommutativeCancellation - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Cancel the redundant (self-adjoint) gates through commutation relations. @@ -48,7 +48,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeCancellation ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -68,7 +68,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeCancellation ### name - + Name of the pass. **Return type** @@ -78,7 +78,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeCancellation ### run - + Run the CommutativeCancellation pass on dag. **Parameters** @@ -100,7 +100,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeCancellation ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.CommutativeInverseCancellation.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.CommutativeInverseCancellation.mdx index cc9ba5f4a2c..7d318527fd9 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.CommutativeInverseCancellation.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.CommutativeInverseCancellation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeInverseCancellation # CommutativeInverseCancellation - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Cancel pairs of inverse gates exploiting commutation relations. @@ -40,7 +40,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeInverseCancellation ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -60,7 +60,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeInverseCancellation ### name - + Name of the pass. **Return type** @@ -70,7 +70,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeInverseCancellation ### run - + Run the CommutativeInverseCancellation pass on dag. **Parameters** @@ -88,7 +88,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeInverseCancellation ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.Commuting2qGateRouter.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.Commuting2qGateRouter.mdx index 495e34e51d8..45baddcf4fe 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.Commuting2qGateRouter.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.Commuting2qGateRouter.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Commuting2qGateRouter # Commuting2qGateRouter - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") A class to swap route one or more commuting gates to the coupling map. @@ -97,7 +97,7 @@ python_api_name: qiskit.transpiler.passes.Commuting2qGateRouter ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -117,7 +117,7 @@ python_api_name: qiskit.transpiler.passes.Commuting2qGateRouter ### name - + Name of the pass. **Return type** @@ -127,7 +127,7 @@ python_api_name: qiskit.transpiler.passes.Commuting2qGateRouter ### run - + Run the pass by decomposing the nodes it applies on. **Parameters** @@ -151,7 +151,7 @@ python_api_name: qiskit.transpiler.passes.Commuting2qGateRouter ### swap\_decompose - + Take an instance of `Commuting2qBlock` and map it to the coupling map. The mapping is done with the swap strategy. @@ -159,7 +159,7 @@ python_api_name: qiskit.transpiler.passes.Commuting2qGateRouter **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`. + * **node** ([*DAGOpNode*](qiskit.dagcircuit.DAGOpNode "qiskit._accelerate.circuit.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. @@ -174,7 +174,7 @@ python_api_name: qiskit.transpiler.passes.Commuting2qGateRouter ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.ConsolidateBlocks.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.ConsolidateBlocks.mdx index 94a24d4962c..f7419ccc4c2 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.ConsolidateBlocks.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.ConsolidateBlocks.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ConsolidateBlocks # ConsolidateBlocks - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Replace each block of consecutive gates by a single Unitary node. @@ -53,7 +53,7 @@ python_api_name: qiskit.transpiler.passes.ConsolidateBlocks ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -73,7 +73,7 @@ python_api_name: qiskit.transpiler.passes.ConsolidateBlocks ### name - + Name of the pass. **Return type** @@ -83,7 +83,7 @@ python_api_name: qiskit.transpiler.passes.ConsolidateBlocks ### run - + Run the ConsolidateBlocks pass on dag. Iterate over each block and replace it with an equivalent Unitary on the same wires. @@ -91,7 +91,7 @@ python_api_name: qiskit.transpiler.passes.ConsolidateBlocks ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.ConstrainedReschedule.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.ConstrainedReschedule.mdx index e8e99668034..448dee8326a 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.ConstrainedReschedule.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.ConstrainedReschedule.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ConstrainedReschedule # ConstrainedReschedule - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Rescheduler pass that updates node start times to conform to the hardware alignments. @@ -73,7 +73,7 @@ python_api_name: qiskit.transpiler.passes.ConstrainedReschedule ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -93,7 +93,7 @@ python_api_name: qiskit.transpiler.passes.ConstrainedReschedule ### name - + Name of the pass. **Return type** @@ -103,7 +103,7 @@ python_api_name: qiskit.transpiler.passes.ConstrainedReschedule ### run - + Run rescheduler. This pass should perform rescheduling to satisfy: @@ -146,7 +146,7 @@ python_api_name: qiskit.transpiler.passes.ConstrainedReschedule ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.ContainsInstruction.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.ContainsInstruction.mdx index 1e46c307a49..b6bdf34b47c 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.ContainsInstruction.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.ContainsInstruction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ContainsInstruction # ContainsInstruction - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") An analysis pass to detect if the DAG contains a specific instruction. @@ -44,7 +44,7 @@ python_api_name: qiskit.transpiler.passes.ContainsInstruction ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -64,7 +64,7 @@ python_api_name: qiskit.transpiler.passes.ContainsInstruction ### name - + Name of the pass. **Return type** @@ -74,13 +74,13 @@ python_api_name: qiskit.transpiler.passes.ContainsInstruction ### run - + Run the ContainsInstruction pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.ConvertConditionsToIfOps.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.ConvertConditionsToIfOps.mdx index ce803712df1..dfbc6a9a0e0 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.ConvertConditionsToIfOps.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.ConvertConditionsToIfOps.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ConvertConditionsToIfOps # ConvertConditionsToIfOps - + 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`. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.ConvertConditionsToIfOps ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.ConvertConditionsToIfOps ### name - + Name of the pass. **Return type** @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.ConvertConditionsToIfOps ### run - + Run a pass on the DAGCircuit. This is implemented by the pass developer. **Parameters** @@ -81,7 +81,7 @@ python_api_name: qiskit.transpiler.passes.ConvertConditionsToIfOps ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.CountOps.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.CountOps.mdx index dc308c940b7..4c24334f4d2 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.CountOps.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.CountOps.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CountOps # CountOps - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Count the operations in a DAG circuit. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.CountOps ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.CountOps ### name - + Name of the pass. **Return type** @@ -67,13 +67,13 @@ python_api_name: qiskit.transpiler.passes.CountOps ### run - + Run the CountOps pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.CountOpsLongestPath.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.CountOpsLongestPath.mdx index e917c95d5ce..30e5e26fcf1 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.CountOpsLongestPath.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.CountOpsLongestPath.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CountOpsLongestPath # CountOpsLongestPath - + 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"). @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.CountOpsLongestPath ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.CountOpsLongestPath ### name - + Name of the pass. **Return type** @@ -67,13 +67,13 @@ python_api_name: qiskit.transpiler.passes.CountOpsLongestPath ### run - + Run the CountOpsLongestPath pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.DAGFixedPoint.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.DAGFixedPoint.mdx index 60b6b9aee6c..f8ea5a1aae3 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.DAGFixedPoint.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.DAGFixedPoint.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.DAGFixedPoint # DAGFixedPoint - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Check if the DAG has reached a fixed point. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.DAGFixedPoint ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.DAGFixedPoint ### name - + Name of the pass. **Return type** @@ -67,13 +67,13 @@ python_api_name: qiskit.transpiler.passes.DAGFixedPoint ### run - + Run the DAGFixedPoint pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.DAGLongestPath.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.DAGLongestPath.mdx index b51eb0caa25..44648ff1fda 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.DAGLongestPath.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.DAGLongestPath.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.DAGLongestPath # DAGLongestPath - + 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. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.passes.DAGLongestPath ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.DAGLongestPath ### name - + Name of the pass. **Return type** @@ -65,13 +65,13 @@ python_api_name: qiskit.transpiler.passes.DAGLongestPath ### run - + Run the DAGLongestPath pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.Decompose.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.Decompose.mdx index 82d3eba005e..9c7b0b418f5 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.Decompose.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.Decompose.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Decompose # Decompose - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Expand a gate in a circuit using its decomposition rules. @@ -41,7 +41,7 @@ python_api_name: qiskit.transpiler.passes.Decompose ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -61,7 +61,7 @@ python_api_name: qiskit.transpiler.passes.Decompose ### name - + Name of the pass. **Return type** @@ -71,7 +71,7 @@ python_api_name: qiskit.transpiler.passes.Decompose ### run - + Run the Decompose pass on dag. **Parameters** @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.Decompose ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.DenseLayout.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.DenseLayout.mdx index e5d4e4c23da..a95a195172c 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.DenseLayout.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.DenseLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.DenseLayout # DenseLayout - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Choose a Layout by finding the most connected subset of qubits. @@ -49,7 +49,7 @@ python_api_name: qiskit.transpiler.passes.DenseLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.DenseLayout ### name - + Name of the pass. **Return type** @@ -79,7 +79,7 @@ python_api_name: qiskit.transpiler.passes.DenseLayout ### run - + Run the DenseLayout pass on dag. Pick a convenient layout depending on the best matching qubit connectivity, and set the property layout. @@ -95,7 +95,7 @@ python_api_name: qiskit.transpiler.passes.DenseLayout ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.Depth.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.Depth.mdx index 23bbaad8454..ece3ed92deb 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.Depth.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.Depth.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Depth # Depth - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Calculate the depth of a DAG circuit. @@ -39,7 +39,7 @@ python_api_name: qiskit.transpiler.passes.Depth ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -59,7 +59,7 @@ python_api_name: qiskit.transpiler.passes.Depth ### name - + Name of the pass. **Return type** @@ -69,13 +69,13 @@ python_api_name: qiskit.transpiler.passes.Depth ### run - + Run the Depth pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.DynamicalDecoupling.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.DynamicalDecoupling.mdx index 5072b58f60c..5cb5cf559a5 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.DynamicalDecoupling.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.DynamicalDecoupling.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.DynamicalDecoupling # DynamicalDecoupling - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Dynamical decoupling insertion pass. @@ -118,7 +118,7 @@ python_api_name: qiskit.transpiler.passes.DynamicalDecoupling ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -138,7 +138,7 @@ python_api_name: qiskit.transpiler.passes.DynamicalDecoupling ### name - + Name of the pass. **Return type** @@ -148,7 +148,7 @@ python_api_name: qiskit.transpiler.passes.DynamicalDecoupling ### run - + Run the DynamicalDecoupling pass on dag. **Parameters** @@ -172,7 +172,7 @@ python_api_name: qiskit.transpiler.passes.DynamicalDecoupling ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.EchoRZXWeylDecomposition.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.EchoRZXWeylDecomposition.mdx index 63056d2f34f..e3846ba2d4c 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.EchoRZXWeylDecomposition.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.EchoRZXWeylDecomposition.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.EchoRZXWeylDecomposition # EchoRZXWeylDecomposition - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Rewrite two-qubit gates using the Weyl decomposition. @@ -44,7 +44,7 @@ python_api_name: qiskit.transpiler.passes.EchoRZXWeylDecomposition ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -64,7 +64,7 @@ python_api_name: qiskit.transpiler.passes.EchoRZXWeylDecomposition ### name - + Name of the pass. **Return type** @@ -74,7 +74,7 @@ python_api_name: qiskit.transpiler.passes.EchoRZXWeylDecomposition ### run - + 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. @@ -98,7 +98,7 @@ python_api_name: qiskit.transpiler.passes.EchoRZXWeylDecomposition ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.ElidePermutations.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.ElidePermutations.mdx index 45aa434fe38..8e9514921cb 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.ElidePermutations.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.ElidePermutations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ElidePermutations # ElidePermutations - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Remove permutation operations from a pre-layout circuit @@ -51,7 +51,7 @@ python_api_name: qiskit.transpiler.passes.ElidePermutations ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -71,7 +71,7 @@ python_api_name: qiskit.transpiler.passes.ElidePermutations ### name - + Name of the pass. **Return type** @@ -81,7 +81,7 @@ python_api_name: qiskit.transpiler.passes.ElidePermutations ### run - + Run the ElidePermutations pass on `dag`. **Parameters** @@ -99,7 +99,7 @@ python_api_name: qiskit.transpiler.passes.ElidePermutations ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.EnlargeWithAncilla.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.EnlargeWithAncilla.mdx index efdb8d8a926..c44d3b163d9 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.EnlargeWithAncilla.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.EnlargeWithAncilla.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.EnlargeWithAncilla # EnlargeWithAncilla - + 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. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.EnlargeWithAncilla ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.EnlargeWithAncilla ### name - + Name of the pass. **Return type** @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.EnlargeWithAncilla ### run - + Run the EnlargeWithAncilla pass on dag. **Parameters** @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.EnlargeWithAncilla ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.FilterOpNodes.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.FilterOpNodes.mdx index 6ba140eb0a3..7fccb59f012 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.FilterOpNodes.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.FilterOpNodes.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.FilterOpNodes # FilterOpNodes - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Remove all operations that match a filter function @@ -62,7 +62,7 @@ python_api_name: qiskit.transpiler.passes.FilterOpNodes ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -82,7 +82,7 @@ python_api_name: qiskit.transpiler.passes.FilterOpNodes ### name - + Name of the pass. **Return type** @@ -92,7 +92,7 @@ python_api_name: qiskit.transpiler.passes.FilterOpNodes ### run - + Run the RemoveBarriers pass on dag. **Return type** @@ -102,7 +102,7 @@ python_api_name: qiskit.transpiler.passes.FilterOpNodes ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.FixedPoint.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.FixedPoint.mdx index 9a27d56ee72..8c5a5f2c962 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.FixedPoint.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.FixedPoint.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.FixedPoint # FixedPoint - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Check if a property reached a fixed point. @@ -43,7 +43,7 @@ python_api_name: qiskit.transpiler.passes.FixedPoint ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -63,7 +63,7 @@ python_api_name: qiskit.transpiler.passes.FixedPoint ### name - + Name of the pass. **Return type** @@ -73,13 +73,13 @@ python_api_name: qiskit.transpiler.passes.FixedPoint ### run - + Run the FixedPoint pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.FullAncillaAllocation.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.FullAncillaAllocation.mdx index 5000ddbba61..af86084c9b0 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.FullAncillaAllocation.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.FullAncillaAllocation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.FullAncillaAllocation # FullAncillaAllocation - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Allocate all idle nodes from the coupling map or target as ancilla on the layout. @@ -47,7 +47,7 @@ python_api_name: qiskit.transpiler.passes.FullAncillaAllocation ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.FullAncillaAllocation ### name - + Name of the pass. **Return type** @@ -77,7 +77,7 @@ python_api_name: qiskit.transpiler.passes.FullAncillaAllocation ### run - + 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) @@ -103,7 +103,7 @@ python_api_name: qiskit.transpiler.passes.FullAncillaAllocation ### update\_status - + Update workflow status. **Parameters** @@ -122,7 +122,7 @@ python_api_name: qiskit.transpiler.passes.FullAncillaAllocation ### validate\_layout - + Checks if all the qregs in `layout_qregs` already exist in `dag_qregs`. Otherwise, raise. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.GateDirection.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.GateDirection.mdx index a7b0bcdb3f4..1a335068946 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.GateDirection.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.GateDirection.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.GateDirection # GateDirection - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Modify asymmetric gates to match the hardware coupling direction. @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.GateDirection ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.GateDirection ### name - + Name of the pass. **Return type** @@ -99,7 +99,7 @@ python_api_name: qiskit.transpiler.passes.GateDirection ### run - + Run the GateDirection pass on dag. Flips the cx nodes to match the directed coupling map. Modifies the input dag. @@ -123,7 +123,7 @@ python_api_name: qiskit.transpiler.passes.GateDirection ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.GatesInBasis.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.GatesInBasis.mdx index 3d3ddc236fa..a23cbbd8c8e 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.GatesInBasis.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.GatesInBasis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.GatesInBasis # GatesInBasis - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Check if all gates in a DAG are in a given set of gates @@ -42,7 +42,7 @@ python_api_name: qiskit.transpiler.passes.GatesInBasis ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -62,7 +62,7 @@ python_api_name: qiskit.transpiler.passes.GatesInBasis ### name - + Name of the pass. **Return type** @@ -72,13 +72,13 @@ python_api_name: qiskit.transpiler.passes.GatesInBasis ### run - + Run the GatesInBasis pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.HLSConfig.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.HLSConfig.mdx index 14b20c1332a..f416a8cc960 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.HLSConfig.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.HLSConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.HLSConfig # HLSConfig - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") The high-level-synthesis config allows to specify a list of “methods” used by [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis") transformation pass to synthesize different types of higher-level objects. @@ -58,7 +58,7 @@ python_api_name: qiskit.transpiler.passes.HLSConfig ### set\_methods - + Sets the list of synthesis methods for a given higher-level-object. This overwrites the lists of methods if also set previously. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.HighLevelSynthesis.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.HighLevelSynthesis.mdx index db37fdcfaff..f3e0b31447d 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.HighLevelSynthesis.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.HighLevelSynthesis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.HighLevelSynthesis # HighLevelSynthesis - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Synthesize higher-level objects and unroll custom definitions. @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.HighLevelSynthesis ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.HighLevelSynthesis ### name - + Name of the pass. **Return type** @@ -99,7 +99,7 @@ python_api_name: qiskit.transpiler.passes.HighLevelSynthesis ### run - + Run the HighLevelSynthesis pass on dag. **Parameters** @@ -122,7 +122,7 @@ python_api_name: qiskit.transpiler.passes.HighLevelSynthesis ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.HoareOptimizer.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.HoareOptimizer.mdx index 85ab18ddb4b..e337c5ed473 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.HoareOptimizer.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.HoareOptimizer.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.HoareOptimizer # HoareOptimizer - + 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) @@ -43,7 +43,7 @@ python_api_name: qiskit.transpiler.passes.HoareOptimizer ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -63,7 +63,7 @@ python_api_name: qiskit.transpiler.passes.HoareOptimizer ### name - + Name of the pass. **Return type** @@ -73,7 +73,7 @@ python_api_name: qiskit.transpiler.passes.HoareOptimizer ### run - + **Parameters** **dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the directed acyclic graph to run on. @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.HoareOptimizer ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.InstructionDurationCheck.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.InstructionDurationCheck.mdx index 865aabf7b0c..575d231e1c6 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.InstructionDurationCheck.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.InstructionDurationCheck.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.InstructionDurationCheck # InstructionDurationCheck - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Duration validation pass for reschedule. @@ -49,7 +49,7 @@ python_api_name: qiskit.transpiler.passes.InstructionDurationCheck ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.InstructionDurationCheck ### name - + Name of the pass. **Return type** @@ -79,7 +79,7 @@ python_api_name: qiskit.transpiler.passes.InstructionDurationCheck ### run - + Run duration validation passes. **Parameters** @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.InstructionDurationCheck ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.InverseCancellation.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.InverseCancellation.mdx index a1505b85725..28f1af5605a 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.InverseCancellation.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.InverseCancellation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.InverseCancellation # InverseCancellation - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Cancel specific Gates which are inverses of each other when they occur back-to- back. @@ -45,7 +45,7 @@ python_api_name: qiskit.transpiler.passes.InverseCancellation ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.InverseCancellation ### name - + Name of the pass. **Return type** @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.InverseCancellation ### run - + Run the InverseCancellation pass on dag. **Parameters** @@ -93,7 +93,7 @@ python_api_name: qiskit.transpiler.passes.InverseCancellation ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.Layout2qDistance.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.Layout2qDistance.mdx index d528dd9cac6..9a323a7b896 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.Layout2qDistance.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.Layout2qDistance.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Layout2qDistance # Layout2qDistance - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Evaluate how good the layout selection was. @@ -44,7 +44,7 @@ python_api_name: qiskit.transpiler.passes.Layout2qDistance ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -64,7 +64,7 @@ python_api_name: qiskit.transpiler.passes.Layout2qDistance ### name - + Name of the pass. **Return type** @@ -74,13 +74,13 @@ python_api_name: qiskit.transpiler.passes.Layout2qDistance ### run - + Run the Layout2qDistance pass on dag. :param dag: DAG to evaluate. :type dag: DAGCircuit ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.LinearFunctionsToPermutations.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.LinearFunctionsToPermutations.mdx index 42b37e4d95e..be6e9b8607e 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.LinearFunctionsToPermutations.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.LinearFunctionsToPermutations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.LinearFunctionsToPermutations # LinearFunctionsToPermutations - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Promotes linear functions to permutations when possible. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.passes.LinearFunctionsToPermutations ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.LinearFunctionsToPermutations ### name - + Name of the pass. **Return type** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.LinearFunctionsToPermutations ### run - + Run the LinearFunctionsToPermutations pass on dag. :param dag: input dag. **Returns** @@ -79,7 +79,7 @@ python_api_name: qiskit.transpiler.passes.LinearFunctionsToPermutations ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.LookaheadSwap.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.LookaheadSwap.mdx index 3f2f4f5a221..a585f1a38fe 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.LookaheadSwap.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.LookaheadSwap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.LookaheadSwap # LookaheadSwap - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Map input circuit onto a backend topology via insertion of SWAPs. @@ -60,7 +60,7 @@ python_api_name: qiskit.transpiler.passes.LookaheadSwap ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -80,7 +80,7 @@ python_api_name: qiskit.transpiler.passes.LookaheadSwap ### name - + Name of the pass. **Return type** @@ -90,7 +90,7 @@ python_api_name: qiskit.transpiler.passes.LookaheadSwap ### run - + Run the LookaheadSwap pass on dag. **Parameters** @@ -115,7 +115,7 @@ python_api_name: qiskit.transpiler.passes.LookaheadSwap ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.MergeAdjacentBarriers.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.MergeAdjacentBarriers.mdx index 75fc34a4972..2d152786471 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.MergeAdjacentBarriers.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.MergeAdjacentBarriers.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.MergeAdjacentBarriers # MergeAdjacentBarriers - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Return a circuit with any adjacent barriers merged together. @@ -72,7 +72,7 @@ python_api_name: qiskit.transpiler.passes.MergeAdjacentBarriers ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -92,7 +92,7 @@ python_api_name: qiskit.transpiler.passes.MergeAdjacentBarriers ### name - + Name of the pass. **Return type** @@ -102,13 +102,13 @@ python_api_name: qiskit.transpiler.passes.MergeAdjacentBarriers ### run - + Run the MergeAdjacentBarriers pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.MinimumPoint.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.MinimumPoint.mdx index 4395180c294..0fab3a917a8 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.MinimumPoint.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.MinimumPoint.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.MinimumPoint # MinimumPoint - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Check if the DAG has reached a relative semi-stable point over previous runs @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.MinimumPoint ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.MinimumPoint ### name - + Name of the pass. **Return type** @@ -85,13 +85,13 @@ python_api_name: qiskit.transpiler.passes.MinimumPoint ### run - + Run the MinimumPoint pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.NormalizeRXAngle.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.NormalizeRXAngle.mdx index 610f5319cba..388a03154c6 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.NormalizeRXAngle.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.NormalizeRXAngle.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.NormalizeRXAngle # NormalizeRXAngle - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Normalize theta parameter of RXGate instruction. @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.NormalizeRXAngle ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -77,7 +77,7 @@ python_api_name: qiskit.transpiler.passes.NormalizeRXAngle ### name - + Name of the pass. **Return type** @@ -87,7 +87,7 @@ python_api_name: qiskit.transpiler.passes.NormalizeRXAngle ### quantize\_angles - + Quantize the RX rotation angles by assigning the same value for the angles that differ within a resolution provided by the user. **Parameters** @@ -106,7 +106,7 @@ python_api_name: qiskit.transpiler.passes.NormalizeRXAngle ### run - + Run the NormalizeRXAngle pass on `dag`. **Parameters** @@ -124,7 +124,7 @@ python_api_name: qiskit.transpiler.passes.NormalizeRXAngle ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.NumTensorFactors.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.NumTensorFactors.mdx index 16ae65b8d28..28ec9ad1b12 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.NumTensorFactors.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.NumTensorFactors.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.NumTensorFactors # NumTensorFactors - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Calculate the number of tensor factors of a DAG circuit. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.NumTensorFactors ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.NumTensorFactors ### name - + Name of the pass. **Return type** @@ -67,13 +67,13 @@ python_api_name: qiskit.transpiler.passes.NumTensorFactors ### run - + Run the NumTensorFactors pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.Optimize1qGates.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.Optimize1qGates.mdx index 1454fbf415b..687b1d5f141 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.Optimize1qGates.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.Optimize1qGates.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGates # Optimize1qGates - + 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. @@ -43,7 +43,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGates ### compose\_u3 - + Return a triple theta, phi, lambda for the product. **u3(theta, phi, lambda)** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGates ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGates ### name - + Name of the pass. **Return type** @@ -85,7 +85,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGates ### run - + Run the Optimize1qGates pass on dag. **Parameters** @@ -107,7 +107,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGates ### update\_status - + Update workflow status. **Parameters** @@ -126,7 +126,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGates ### yzy\_to\_zyz - + Express a Y.Z.Y single qubit gate as a Z.Y.Z gate. Solve the equation diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.Optimize1qGatesDecomposition.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.Optimize1qGatesDecomposition.mdx index ed2c6a521ef..1a31e1d145f 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.Optimize1qGatesDecomposition.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.Optimize1qGatesDecomposition.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesDecomposition # Optimize1qGatesDecomposition - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Optimize chains of single-qubit gates by combining them into a single gate. @@ -51,7 +51,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesDecomposition ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -71,7 +71,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesDecomposition ### name - + Name of the pass. **Return type** @@ -81,7 +81,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesDecomposition ### run - + Run the Optimize1qGatesDecomposition pass on dag. **Parameters** @@ -99,7 +99,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesDecomposition ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.mdx index cb8869c8774..ef045485344 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation # Optimize1qGatesSimpleCommutation - + 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`. @@ -47,7 +47,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation ### name - + Name of the pass. **Return type** @@ -77,7 +77,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation ### run - + **Parameters** **dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the DAG to be optimized. @@ -93,7 +93,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.OptimizeAnnotated.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.OptimizeAnnotated.mdx index 5a15177682a..e713d60c052 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.OptimizeAnnotated.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.OptimizeAnnotated.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeAnnotated # OptimizeAnnotated - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Optimization pass on circuits with annotated operations. @@ -52,7 +52,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeAnnotated ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -72,7 +72,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeAnnotated ### name - + Name of the pass. **Return type** @@ -82,7 +82,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeAnnotated ### run - + Run the OptimizeAnnotated pass on dag. **Parameters** @@ -100,7 +100,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeAnnotated ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.OptimizeCliffords.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.OptimizeCliffords.mdx index aa78eedd830..b6a417ce757 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.OptimizeCliffords.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.OptimizeCliffords.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeCliffords # OptimizeCliffords - + 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. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeCliffords ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeCliffords ### name - + Name of the pass. **Return type** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeCliffords ### run - + Run the OptimizeCliffords pass on dag. **Parameters** @@ -83,7 +83,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeCliffords ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.PadDelay.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.PadDelay.mdx index 587089d3bbe..394592a0c24 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.PadDelay.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.PadDelay.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.PadDelay # PadDelay - + Bases: `BasePadding` Padding idle time with Delay instructions. @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.PadDelay ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -87,7 +87,7 @@ python_api_name: qiskit.transpiler.passes.PadDelay ### name - + Name of the pass. **Return type** @@ -97,7 +97,7 @@ python_api_name: qiskit.transpiler.passes.PadDelay ### run - + Run the padding pass on `dag`. **Parameters** @@ -119,7 +119,7 @@ python_api_name: qiskit.transpiler.passes.PadDelay ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.PadDynamicalDecoupling.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.PadDynamicalDecoupling.mdx index 66b20dc2e42..8628a347b02 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.PadDynamicalDecoupling.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.PadDynamicalDecoupling.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.PadDynamicalDecoupling # PadDynamicalDecoupling - + Bases: `BasePadding` Dynamical decoupling insertion pass. @@ -125,7 +125,7 @@ python_api_name: qiskit.transpiler.passes.PadDynamicalDecoupling ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -145,7 +145,7 @@ python_api_name: qiskit.transpiler.passes.PadDynamicalDecoupling ### name - + Name of the pass. **Return type** @@ -155,7 +155,7 @@ python_api_name: qiskit.transpiler.passes.PadDynamicalDecoupling ### run - + Run the padding pass on `dag`. **Parameters** @@ -177,7 +177,7 @@ python_api_name: qiskit.transpiler.passes.PadDynamicalDecoupling ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.PulseGates.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.PulseGates.mdx index f3cceeab4f4..af8873aa94b 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.PulseGates.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.PulseGates.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.PulseGates # PulseGates - + Bases: `CalibrationBuilder` Pulse gate adding pass. @@ -54,7 +54,7 @@ python_api_name: qiskit.transpiler.passes.PulseGates ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -74,7 +74,7 @@ python_api_name: qiskit.transpiler.passes.PulseGates ### get\_calibration - + Gets the calibrated schedule for the given instruction and qubits. **Parameters** @@ -97,7 +97,7 @@ python_api_name: qiskit.transpiler.passes.PulseGates ### name - + Name of the pass. **Return type** @@ -107,7 +107,7 @@ python_api_name: qiskit.transpiler.passes.PulseGates ### run - + Run the calibration adder pass on dag. **Parameters** @@ -125,7 +125,7 @@ python_api_name: qiskit.transpiler.passes.PulseGates ### supported - + Determine if a given node supports the calibration. **Parameters** @@ -144,7 +144,7 @@ python_api_name: qiskit.transpiler.passes.PulseGates ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.RXCalibrationBuilder.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.RXCalibrationBuilder.mdx index 30d092d3e5b..7f3002c6dda 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.RXCalibrationBuilder.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.RXCalibrationBuilder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.RXCalibrationBuilder # RXCalibrationBuilder - + Bases: `CalibrationBuilder` Add single-pulse RX calibrations that are bootstrapped from the SX calibration. @@ -85,7 +85,7 @@ python_api_name: qiskit.transpiler.passes.RXCalibrationBuilder ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -105,7 +105,7 @@ python_api_name: qiskit.transpiler.passes.RXCalibrationBuilder ### get\_calibration - + Generate RX calibration for the rotation angle specified in node\_op. **Return type** @@ -115,7 +115,7 @@ python_api_name: qiskit.transpiler.passes.RXCalibrationBuilder ### name - + Name of the pass. **Return type** @@ -125,7 +125,7 @@ python_api_name: qiskit.transpiler.passes.RXCalibrationBuilder ### run - + Run the calibration adder pass on dag. **Parameters** @@ -143,7 +143,7 @@ python_api_name: qiskit.transpiler.passes.RXCalibrationBuilder ### supported - + Check if the calibration for SX gate exists and it’s a single DRAG pulse. **Return type** @@ -153,7 +153,7 @@ python_api_name: qiskit.transpiler.passes.RXCalibrationBuilder ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.RZXCalibrationBuilder.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.RZXCalibrationBuilder.mdx index 62cc2809cb0..7bd856f893d 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.RZXCalibrationBuilder.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.RZXCalibrationBuilder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder # RZXCalibrationBuilder - + 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). @@ -47,7 +47,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder ### get\_calibration - + Builds the calibration schedule for the RZXGate(theta) with echos. **Parameters** @@ -92,7 +92,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder ### name - + Name of the pass. **Return type** @@ -102,7 +102,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder ### rescale\_cr\_inst - + A builder macro to play stretched pulse. **Parameters** @@ -126,7 +126,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder ### run - + Run the calibration adder pass on dag. **Parameters** @@ -144,7 +144,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder ### supported - + Determine if a given node supports the calibration. **Parameters** @@ -163,7 +163,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.mdx index 9877ba1f2c4..4d01aa19da6 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho # RZXCalibrationBuilderNoEcho - + 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. @@ -49,7 +49,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho ### get\_calibration - + Builds the calibration schedule for the RZXGate(theta) without echos. **Parameters** @@ -94,7 +94,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho ### name - + Name of the pass. **Return type** @@ -104,7 +104,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho ### rescale\_cr\_inst - + A builder macro to play stretched pulse. **Parameters** @@ -128,7 +128,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho ### run - + Run the calibration adder pass on dag. **Parameters** @@ -146,7 +146,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho ### supported - + Determine if a given node supports the calibration. **Parameters** @@ -165,7 +165,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveBarriers.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveBarriers.mdx index dad004772fc..704fc59abed 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveBarriers.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveBarriers.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.RemoveBarriers # RemoveBarriers - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Return a circuit with any barrier removed. @@ -54,7 +54,7 @@ python_api_name: qiskit.transpiler.passes.RemoveBarriers ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -74,7 +74,7 @@ python_api_name: qiskit.transpiler.passes.RemoveBarriers ### name - + Name of the pass. **Return type** @@ -84,7 +84,7 @@ python_api_name: qiskit.transpiler.passes.RemoveBarriers ### run - + Run the RemoveBarriers pass on dag. **Return type** @@ -94,7 +94,7 @@ python_api_name: qiskit.transpiler.passes.RemoveBarriers ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.mdx index ac4e53c4536..7680c215a7e 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure # RemoveDiagonalGatesBeforeMeasure - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Remove diagonal gates (including diagonal 2Q gates) before a measurement. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure ### name - + Name of the pass. **Return type** @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure ### run - + Run the RemoveDiagonalGatesBeforeMeasure pass on dag. **Parameters** @@ -85,7 +85,7 @@ python_api_name: qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveFinalMeasurements.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveFinalMeasurements.mdx index 97a92b1c1fd..fa4cee65bf7 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveFinalMeasurements.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveFinalMeasurements.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.RemoveFinalMeasurements # RemoveFinalMeasurements - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Remove final measurements and barriers at the end of a circuit. @@ -39,7 +39,7 @@ python_api_name: qiskit.transpiler.passes.RemoveFinalMeasurements ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -59,7 +59,7 @@ python_api_name: qiskit.transpiler.passes.RemoveFinalMeasurements ### name - + Name of the pass. **Return type** @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.RemoveFinalMeasurements ### run - + Run the RemoveFinalMeasurements pass on dag. **Parameters** @@ -87,7 +87,7 @@ python_api_name: qiskit.transpiler.passes.RemoveFinalMeasurements ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveFinalReset.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveFinalReset.mdx index 1826b6f09dc..c108beee8f8 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveFinalReset.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveFinalReset.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.RemoveFinalReset # RemoveFinalReset - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Remove reset when it is the final instruction on a qubit wire. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.passes.RemoveFinalReset ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.RemoveFinalReset ### name - + Name of the pass. **Return type** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.RemoveFinalReset ### run - + Run the RemoveFinalReset pass on dag. **Parameters** @@ -83,7 +83,7 @@ python_api_name: qiskit.transpiler.passes.RemoveFinalReset ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveResetInZeroState.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveResetInZeroState.mdx index bc1efd68c87..1a82112b859 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveResetInZeroState.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.RemoveResetInZeroState.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.RemoveResetInZeroState # RemoveResetInZeroState - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Remove reset gate when the qubit is in zero state. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.passes.RemoveResetInZeroState ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.RemoveResetInZeroState ### name - + Name of the pass. **Return type** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.RemoveResetInZeroState ### run - + Run the RemoveResetInZeroState pass on dag. **Parameters** @@ -83,7 +83,7 @@ python_api_name: qiskit.transpiler.passes.RemoveResetInZeroState ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.ResetAfterMeasureSimplification.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.ResetAfterMeasureSimplification.mdx index 9e4a67f0f59..2eb419b5640 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.ResetAfterMeasureSimplification.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.ResetAfterMeasureSimplification.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ResetAfterMeasureSimplification # ResetAfterMeasureSimplification - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") This pass replaces reset after measure with a conditional X gate. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.ResetAfterMeasureSimplification ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.ResetAfterMeasureSimplification ### name - + Name of the pass. **Return type** @@ -67,13 +67,13 @@ python_api_name: qiskit.transpiler.passes.ResetAfterMeasureSimplification ### run - + Run the pass on a dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.SabreLayout.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.SabreLayout.mdx index 4ca5770c9f4..7fb1efc1c46 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.SabreLayout.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.SabreLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.SabreLayout # SabreLayout - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Choose a Layout via iterative bidirectional routing of the input circuit. @@ -129,7 +129,7 @@ python_api_name: qiskit.transpiler.passes.SabreLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -149,7 +149,7 @@ python_api_name: qiskit.transpiler.passes.SabreLayout ### name - + Name of the pass. **Return type** @@ -159,7 +159,7 @@ python_api_name: qiskit.transpiler.passes.SabreLayout ### run - + Run the SabreLayout pass on dag. **Parameters** @@ -183,7 +183,7 @@ python_api_name: qiskit.transpiler.passes.SabreLayout ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.SabrePreLayout.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.SabrePreLayout.mdx index 01e69504fad..c344e476853 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.SabrePreLayout.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.SabrePreLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.SabrePreLayout # SabrePreLayout - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Choose a starting layout to use for additional Sabre layout trials. @@ -99,7 +99,7 @@ python_api_name: qiskit.transpiler.passes.SabrePreLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -119,7 +119,7 @@ python_api_name: qiskit.transpiler.passes.SabrePreLayout ### name - + Name of the pass. **Return type** @@ -129,7 +129,7 @@ python_api_name: qiskit.transpiler.passes.SabrePreLayout ### run - + Run the SabrePreLayout pass on dag. The discovered starting layout is written to the property set value `sabre_starting_layouts`. @@ -141,7 +141,7 @@ python_api_name: qiskit.transpiler.passes.SabrePreLayout ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.SabreSwap.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.SabreSwap.mdx index 834a5f984bb..cc7d344a653 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.SabreSwap.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.SabreSwap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.SabreSwap # SabreSwap - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Map input circuit onto a backend topology via insertion of SWAPs. @@ -95,7 +95,7 @@ python_api_name: qiskit.transpiler.passes.SabreSwap ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -115,7 +115,7 @@ python_api_name: qiskit.transpiler.passes.SabreSwap ### name - + Name of the pass. **Return type** @@ -125,7 +125,7 @@ python_api_name: qiskit.transpiler.passes.SabreSwap ### run - + Run the SabreSwap pass on dag. **Parameters** @@ -148,7 +148,7 @@ python_api_name: qiskit.transpiler.passes.SabreSwap ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.SetIOLatency.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.SetIOLatency.mdx index b4c5096f538..d66f685e1c6 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.SetIOLatency.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.SetIOLatency.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.SetIOLatency # SetIOLatency - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Set IOLatency information to the input circuit. @@ -46,7 +46,7 @@ python_api_name: qiskit.transpiler.passes.SetIOLatency ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -66,7 +66,7 @@ python_api_name: qiskit.transpiler.passes.SetIOLatency ### name - + Name of the pass. **Return type** @@ -76,7 +76,7 @@ python_api_name: qiskit.transpiler.passes.SetIOLatency ### run - + Add IO latency information. **Parameters** @@ -86,7 +86,7 @@ python_api_name: qiskit.transpiler.passes.SetIOLatency ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.SetLayout.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.SetLayout.mdx index f71be5a2e41..778e28f4715 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.SetLayout.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.SetLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.SetLayout # SetLayout - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Set the `layout` property to the given layout. @@ -48,7 +48,7 @@ python_api_name: qiskit.transpiler.passes.SetLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -68,7 +68,7 @@ python_api_name: qiskit.transpiler.passes.SetLayout ### name - + Name of the pass. **Return type** @@ -78,7 +78,7 @@ python_api_name: qiskit.transpiler.passes.SetLayout ### run - + Run the SetLayout pass on `dag`. **Parameters** @@ -96,7 +96,7 @@ python_api_name: qiskit.transpiler.passes.SetLayout ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.Size.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.Size.mdx index aded199863e..8e8190ce065 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.Size.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.Size.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Size # Size - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Calculate the size of a DAG circuit. @@ -41,7 +41,7 @@ python_api_name: qiskit.transpiler.passes.Size ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -61,7 +61,7 @@ python_api_name: qiskit.transpiler.passes.Size ### name - + Name of the pass. **Return type** @@ -71,13 +71,13 @@ python_api_name: qiskit.transpiler.passes.Size ### run - + Run the Size pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.SolovayKitaev.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.SolovayKitaev.mdx index f8abed0e116..4d3651b8de1 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.SolovayKitaev.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.SolovayKitaev.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.SolovayKitaev # SolovayKitaev - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Approximately decompose 1q gates to a discrete basis using the Solovay-Kitaev algorithm. @@ -124,7 +124,7 @@ python_api_name: qiskit.transpiler.passes.SolovayKitaev ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -144,7 +144,7 @@ python_api_name: qiskit.transpiler.passes.SolovayKitaev ### name - + Name of the pass. **Return type** @@ -154,7 +154,7 @@ python_api_name: qiskit.transpiler.passes.SolovayKitaev ### run - + Run the `SolovayKitaev` pass on dag. **Parameters** @@ -176,7 +176,7 @@ python_api_name: qiskit.transpiler.passes.SolovayKitaev ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.StarPreRouting.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.StarPreRouting.mdx index f4b98b6cf54..6a4093d646f 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.StarPreRouting.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.StarPreRouting.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.StarPreRouting # StarPreRouting - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Run star to linear pre-routing @@ -56,7 +56,7 @@ python_api_name: qiskit.transpiler.passes.StarPreRouting ### collect\_all\_matching\_blocks - + Collects all blocks that match a given filtering function filter\_fn. This iteratively finds the largest block that does not match filter\_fn, then the largest block that matches filter\_fn, and so on, until no more uncollected nodes remain. Intuitively, finding larger blocks of non-matching nodes helps to find larger blocks of matching nodes later on. The option `min_block_size` specifies the minimum number of gates in the block for the block to be collected. By default, blocks are collected in the direction from the inputs towards the outputs of the circuit. The option `collect_from_back` allows to change this direction, that is collect blocks from the outputs towards the inputs of the circuit. @@ -66,13 +66,13 @@ python_api_name: qiskit.transpiler.passes.StarPreRouting ### collect\_matching\_block - + Iteratively collects the largest block of input nodes (that is, nodes with `_in_degree` equal to 0) that match a given filtering function. Examples of this include collecting blocks of swap gates, blocks of linear gates (CXs and SWAPs), blocks of Clifford gates, blocks of single-qubit gates, blocks of two-qubit gates, etc. Here ‘iteratively’ means that once a node is collected, the `_in_degree` of each of its immediate successor is decreased by 1, allowing more nodes to become input and to be eligible for collecting into the current block. Returns the block of collected nodes. ### determine\_star\_blocks\_processing - + Returns star blocks in dag and the processing order of nodes within these star blocks :param dag: a dag on which star blocks should be determined. :type dag: DAGCircuit or DAGDependency :param min\_block\_size: minimum number of two-qubit gates in a star block. :type min\_block\_size: int **Returns** @@ -86,7 +86,7 @@ python_api_name: qiskit.transpiler.passes.StarPreRouting ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -106,7 +106,7 @@ python_api_name: qiskit.transpiler.passes.StarPreRouting ### name - + Name of the pass. **Return type** @@ -116,7 +116,7 @@ python_api_name: qiskit.transpiler.passes.StarPreRouting ### run - + Run a pass on the DAGCircuit. This is implemented by the pass developer. **Parameters** @@ -130,7 +130,7 @@ python_api_name: qiskit.transpiler.passes.StarPreRouting ### star\_preroute - + Returns star blocks in dag and the processing order of nodes within these star blocks :param dag: a dag on which star prerouting should be performed. :type dag: DAGCircuit or DAGDependency :param blocks: a list of star blocks in the given dag. :type blocks: List\[StarBlock] :param processing\_order: a list of operations specifying :type processing\_order: Union\[List\[DAGOpNode], List\[DAGDepNode]] :param processing order: **Returns** @@ -144,7 +144,7 @@ python_api_name: qiskit.transpiler.passes.StarPreRouting ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.StochasticSwap.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.StochasticSwap.mdx index 82b1b645dc0..624c4177892 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.StochasticSwap.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.StochasticSwap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.StochasticSwap # StochasticSwap - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Map a DAGCircuit onto a coupling\_map adding swap gates. @@ -56,7 +56,7 @@ python_api_name: qiskit.transpiler.passes.StochasticSwap ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -76,7 +76,7 @@ python_api_name: qiskit.transpiler.passes.StochasticSwap ### name - + Name of the pass. **Return type** @@ -86,7 +86,7 @@ python_api_name: qiskit.transpiler.passes.StochasticSwap ### run - + Run the StochasticSwap pass on dag. **Parameters** @@ -109,7 +109,7 @@ python_api_name: qiskit.transpiler.passes.StochasticSwap ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.TemplateOptimization.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.TemplateOptimization.mdx index ff84ea2f4f3..1b4210018f5 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.TemplateOptimization.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.TemplateOptimization.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.TemplateOptimization # TemplateOptimization - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Class for the template optimization pass. @@ -42,7 +42,7 @@ python_api_name: qiskit.transpiler.passes.TemplateOptimization ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -62,7 +62,7 @@ python_api_name: qiskit.transpiler.passes.TemplateOptimization ### name - + Name of the pass. **Return type** @@ -72,7 +72,7 @@ python_api_name: qiskit.transpiler.passes.TemplateOptimization ### run - + **Parameters** **dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG circuit. @@ -92,7 +92,7 @@ python_api_name: qiskit.transpiler.passes.TemplateOptimization ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.TimeUnitConversion.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.TimeUnitConversion.mdx index 0e9d282c227..8196630cd11 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.TimeUnitConversion.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.TimeUnitConversion.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.TimeUnitConversion # TimeUnitConversion - + 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. @@ -50,7 +50,7 @@ python_api_name: qiskit.transpiler.passes.TimeUnitConversion ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -70,7 +70,7 @@ python_api_name: qiskit.transpiler.passes.TimeUnitConversion ### name - + Name of the pass. **Return type** @@ -80,7 +80,7 @@ python_api_name: qiskit.transpiler.passes.TimeUnitConversion ### run - + Run the TimeUnitAnalysis pass on dag. **Parameters** @@ -102,7 +102,7 @@ python_api_name: qiskit.transpiler.passes.TimeUnitConversion ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.TranslateParameterizedGates.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.TranslateParameterizedGates.mdx index 75c54e95fcb..a5425b41826 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.TranslateParameterizedGates.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.TranslateParameterizedGates.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.TranslateParameterizedGates # TranslateParameterizedGates - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Translate parameterized gates to a supported basis set. @@ -92,7 +92,7 @@ python_api_name: qiskit.transpiler.passes.TranslateParameterizedGates ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -112,7 +112,7 @@ python_api_name: qiskit.transpiler.passes.TranslateParameterizedGates ### name - + Name of the pass. **Return type** @@ -122,7 +122,7 @@ python_api_name: qiskit.transpiler.passes.TranslateParameterizedGates ### run - + Run the transpiler pass. **Parameters** @@ -144,7 +144,7 @@ python_api_name: qiskit.transpiler.passes.TranslateParameterizedGates ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.TrivialLayout.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.TrivialLayout.mdx index d9693942173..987b03643aa 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.TrivialLayout.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.TrivialLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.TrivialLayout # TrivialLayout - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Choose a Layout by assigning `n` circuit qubits to device qubits `0, .., n-1`. @@ -51,7 +51,7 @@ python_api_name: qiskit.transpiler.passes.TrivialLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -71,7 +71,7 @@ python_api_name: qiskit.transpiler.passes.TrivialLayout ### name - + Name of the pass. **Return type** @@ -81,7 +81,7 @@ python_api_name: qiskit.transpiler.passes.TrivialLayout ### run - + Run the TrivialLayout pass on dag. **Parameters** @@ -95,7 +95,7 @@ python_api_name: qiskit.transpiler.passes.TrivialLayout ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.UnitarySynthesis.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.UnitarySynthesis.mdx index e344ea9e3ed..ce79d1f0e26 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.UnitarySynthesis.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.UnitarySynthesis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.UnitarySynthesis # UnitarySynthesis - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Synthesize gates according to their basis gates. @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.UnitarySynthesis ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -77,7 +77,7 @@ python_api_name: qiskit.transpiler.passes.UnitarySynthesis ### name - + Name of the pass. **Return type** @@ -87,7 +87,7 @@ python_api_name: qiskit.transpiler.passes.UnitarySynthesis ### run - + Run the UnitarySynthesis pass on `dag`. **Parameters** @@ -105,7 +105,7 @@ python_api_name: qiskit.transpiler.passes.UnitarySynthesis ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.Unroll3qOrMore.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.Unroll3qOrMore.mdx index e07f6ddf70c..329b5730267 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.Unroll3qOrMore.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.Unroll3qOrMore.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Unroll3qOrMore # Unroll3qOrMore - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Recursively expands 3q+ gates until the circuit only contains 2q or 1q gates. @@ -42,7 +42,7 @@ python_api_name: qiskit.transpiler.passes.Unroll3qOrMore ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -62,7 +62,7 @@ python_api_name: qiskit.transpiler.passes.Unroll3qOrMore ### name - + Name of the pass. **Return type** @@ -72,7 +72,7 @@ python_api_name: qiskit.transpiler.passes.Unroll3qOrMore ### run - + Run the Unroll3qOrMore pass on dag. **Parameters** @@ -94,7 +94,7 @@ python_api_name: qiskit.transpiler.passes.Unroll3qOrMore ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.UnrollCustomDefinitions.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.UnrollCustomDefinitions.mdx index b05d842181c..ffc9919ee69 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.UnrollCustomDefinitions.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.UnrollCustomDefinitions.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.UnrollCustomDefinitions # UnrollCustomDefinitions - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Unrolls instructions with custom definitions. @@ -53,7 +53,7 @@ python_api_name: qiskit.transpiler.passes.UnrollCustomDefinitions ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -73,7 +73,7 @@ python_api_name: qiskit.transpiler.passes.UnrollCustomDefinitions ### name - + Name of the pass. **Return type** @@ -83,7 +83,7 @@ python_api_name: qiskit.transpiler.passes.UnrollCustomDefinitions ### run - + Run the UnrollCustomDefinitions pass on dag. **Parameters** @@ -106,7 +106,7 @@ python_api_name: qiskit.transpiler.passes.UnrollCustomDefinitions ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.UnrollForLoops.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.UnrollForLoops.mdx index fed1849a940..8acf97e2ba6 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.UnrollForLoops.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.UnrollForLoops.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.UnrollForLoops # UnrollForLoops - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") `UnrollForLoops` transpilation pass unrolls for-loops when possible. @@ -45,7 +45,7 @@ python_api_name: qiskit.transpiler.passes.UnrollForLoops ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.UnrollForLoops ### name - + Name of the pass. **Return type** @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.UnrollForLoops ### run - + Run the UnrollForLoops pass on `dag`. **Parameters** @@ -93,7 +93,7 @@ python_api_name: qiskit.transpiler.passes.UnrollForLoops ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.VF2Layout.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.VF2Layout.mdx index e43a5257d7a..b30c9acf4a1 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.VF2Layout.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.VF2Layout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.VF2Layout # VF2Layout - + 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++. @@ -71,7 +71,7 @@ python_api_name: qiskit.transpiler.passes.VF2Layout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -91,7 +91,7 @@ python_api_name: qiskit.transpiler.passes.VF2Layout ### name - + Name of the pass. **Return type** @@ -101,13 +101,13 @@ python_api_name: qiskit.transpiler.passes.VF2Layout ### run - + run the layout method ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.VF2PostLayout.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.VF2PostLayout.mdx index a5482043e15..ca339c5a6e7 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.VF2PostLayout.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.VF2PostLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.VF2PostLayout # VF2PostLayout - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") A pass for improving an existing Layout after transpilation of a circuit onto a Coupling graph, as a subgraph isomorphism problem, solved by VF2++. @@ -74,7 +74,7 @@ python_api_name: qiskit.transpiler.passes.VF2PostLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -94,7 +94,7 @@ python_api_name: qiskit.transpiler.passes.VF2PostLayout ### name - + Name of the pass. **Return type** @@ -104,13 +104,13 @@ python_api_name: qiskit.transpiler.passes.VF2PostLayout ### run - + run the layout method ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.ValidatePulseGates.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.ValidatePulseGates.mdx index f52be5fb92b..f7cc1c2e94b 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.ValidatePulseGates.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.ValidatePulseGates.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ValidatePulseGates # ValidatePulseGates - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Check custom gate length. @@ -51,7 +51,7 @@ python_api_name: qiskit.transpiler.passes.ValidatePulseGates ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -71,7 +71,7 @@ python_api_name: qiskit.transpiler.passes.ValidatePulseGates ### name - + Name of the pass. **Return type** @@ -81,7 +81,7 @@ python_api_name: qiskit.transpiler.passes.ValidatePulseGates ### run - + Run the pulse gate validation attached to `dag`. **Parameters** @@ -103,7 +103,7 @@ python_api_name: qiskit.transpiler.passes.ValidatePulseGates ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.Width.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.Width.mdx index 25e2c19a066..d75eb599726 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.Width.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.Width.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Width # Width - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Calculate the width of a DAG circuit. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.Width ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.Width ### name - + Name of the pass. **Return type** @@ -67,13 +67,13 @@ python_api_name: qiskit.transpiler.passes.Width ### run - + Run the Width pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin.mdx index 184f9564360..13eccb2773a 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugi # AQCSynthesisPlugin - + Bases: [`UnitarySynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin") An AQC-based Qiskit unitary synthesis plugin. @@ -157,7 +157,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugi ### run - + Run synthesis for the given unitary matrix **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation.mdx index 36be49933e7..df511d9d656 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynt # ACGSynthesisPermutation - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") The permutation synthesis plugin based on the Alon, Chung, Graham method. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynt ### run - + Run synthesis for the given Permutation. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford.mdx index 1da0a01c7f2..4d41e80b224 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynth # AGSynthesisClifford - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") Clifford synthesis plugin based on the Aaronson-Gottesman method. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynth ### run - + Run synthesis for the given Clifford. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford.mdx index 7843a1fab61..7a046bc9a30 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynth # BMSynthesisClifford - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") Clifford synthesis plugin based on the Bravyi-Maslov method. @@ -21,7 +21,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynth ### run - + Run synthesis for the given Clifford. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation.mdx index ec41ef751ea..645261007d9 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSy # BasicSynthesisPermutation - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") The permutation synthesis plugin based on sorting. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSy ### run - + Run synthesis for the given Permutation. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford.mdx index 0300fc677d8..53e8fad0b1d 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.Default # DefaultSynthesisClifford - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") The default clifford synthesis plugin. @@ -21,7 +21,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.Default ### run - + Run synthesis for the given Clifford. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction.mdx index 636517c9971..84632a5f314 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.Default # DefaultSynthesisLinearFunction - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") The default linear function synthesis plugin. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.Default ### run - + Run synthesis for the given LinearFunction. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford.mdx index d7df7bb3586..83215bcedb9 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedyS # GreedySynthesisClifford - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") Clifford synthesis plugin based on the greedy synthesis Bravyi-Hu-Maslov-Shaydulin method. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedyS ### run - + Run synthesis for the given Clifford. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction.mdx index e9ec256ccb4..c76f5c55e6b 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynt # KMSSynthesisLinearFunction - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") Linear function synthesis plugin based on the Kutin-Moulton-Smithline method. @@ -29,7 +29,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynt ### run - + Run synthesis for the given LinearFunction. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation.mdx index 336d0608ed0..45125aa9ab7 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynt # KMSSynthesisPermutation - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") The permutation synthesis plugin based on the Kutin, Moulton, Smithline method. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynt ### run - + Run synthesis for the given Permutation. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford.mdx index 29cb813a391..8a1c77811e2 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLn # LayerLnnSynthesisClifford - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") Clifford synthesis plugin based on the Bravyi-Maslov method to synthesize Cliffords into layers, with each layer synthesized adhering to LNN connectivity. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLn ### run - + Run synthesis for the given Clifford. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford.mdx index 8d785971280..36ad509b4ba 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSy # LayerSynthesisClifford - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") Clifford synthesis plugin based on the Bravyi-Maslov method to synthesize Cliffords into layers. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSy ### run - + Run synthesis for the given Clifford. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction.mdx index b8296d28346..5528c8d04d4 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynt # PMHSynthesisLinearFunction - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") Linear function synthesis plugin based on the Patel-Markov-Hayes method. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynt ### run - + Run synthesis for the given LinearFunction. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation.mdx index bd66dde11fd..e6fbbac5f67 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSw # TokenSwapperSynthesisPermutation - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") The permutation synthesis plugin based on the token swapper algorithm. @@ -33,7 +33,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSw ### run - + Run synthesis for the given Permutation. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.mdx index a4932f2f690..29ef6aff66f 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlu # HighLevelSynthesisPlugin - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Abstract high-level synthesis plugin class. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlu ### run - + Run synthesis for the given Operation. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.mdx index 9c24c885455..902d5a5acbb 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlu # HighLevelSynthesisPluginManager - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class tracking the installed high-level-synthesis plugins. @@ -17,13 +17,13 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlu ### method - + Returns the plugin for `op_name` and `method_name`. ### method\_names - + Returns plugin methods for op\_name. diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.mdx index d574cae3f20..baa33fc402d 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugi # UnitarySynthesisPlugin - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Abstract unitary synthesis plugin class @@ -176,7 +176,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugi ### run - + Run synthesis for the given unitary matrix **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.mdx index 5d2ecc20e2b..526a1aff3a5 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugi # UnitarySynthesisPluginManager - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Unitary Synthesis plugin manager class diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names.mdx index 2c1895a4cea..f3c14c03267 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_ # qiskit.transpiler.passes.synthesis.plugin.high\_level\_synthesis\_plugin\_names - + Return a list of plugin names installed for a given high level object name **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.mdx index 668e073fcad..7dbd26b88d4 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plu # qiskit.transpiler.passes.synthesis.plugin.unitary\_synthesis\_plugin\_names - + Return a list of installed unitary synthesis plugin names **Returns** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis.mdx index d438df741f6..1901524aba4 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.Sol # SolovayKitaevSynthesis - + Bases: [`UnitarySynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin") A Solovay-Kitaev Qiskit unitary synthesis plugin. @@ -149,7 +149,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.Sol ### run - + Run synthesis for the given unitary matrix **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis.mdx b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis.mdx index b1084da5a62..d3a75bec753 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUni # DefaultUnitarySynthesis - + Bases: [`UnitarySynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin") The default unitary synthesis plugin. @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUni ### run - + Run synthesis for the given unitary matrix **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.mdx b/docs/api/qiskit/dev/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.mdx index 9f809666a39..ca405017474 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePl # PassManagerStagePlugin - + 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"). @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePl ### pass\_manager - + This method is designed to return a [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") for the stage this implements **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.mdx b/docs/api/qiskit/dev/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.mdx index f1716499f03..768df7e20ea 100644 --- a/docs/api/qiskit/dev/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.mdx +++ b/docs/api/qiskit/dev/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePl # PassManagerStagePluginManager - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Manager class for preset pass manager stage plugins. @@ -17,7 +17,7 @@ python_api_name: qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePl ### get\_passmanager\_stage - + Get a stage **Return type** diff --git a/docs/api/qiskit/dev/qiskit.visualization.array_to_latex.mdx b/docs/api/qiskit/dev/qiskit.visualization.array_to_latex.mdx index 66fbf7086ff..92da7230474 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.array_to_latex.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.array_to_latex.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.array_to_latex # qiskit.visualization.array\_to\_latex - + Latex representation of a complex numpy array (with dimension 1 or 2) **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.visualization.circuit_drawer.mdx b/docs/api/qiskit/dev/qiskit.visualization.circuit_drawer.mdx index 6295dbb42aa..4895dff95b9 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.circuit_drawer.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.circuit_drawer.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.circuit_drawer # qiskit.visualization.circuit\_drawer - + Draw the quantum circuit. Use the output parameter to choose the drawing format: **text**: ASCII art TextDrawing that can be printed in the console. diff --git a/docs/api/qiskit/dev/qiskit.visualization.dag_drawer.mdx b/docs/api/qiskit/dev/qiskit.visualization.dag_drawer.mdx index d57394f7d31..18400897fe2 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.dag_drawer.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.dag_drawer.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.dag_drawer # qiskit.visualization.dag\_drawer - + 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)") function from the `rustworkx` package to draw the DAG. diff --git a/docs/api/qiskit/dev/qiskit.visualization.pass_manager_drawer.mdx b/docs/api/qiskit/dev/qiskit.visualization.pass_manager_drawer.mdx index 02e293a41c7..8da6de737ed 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.pass_manager_drawer.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.pass_manager_drawer.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.pass_manager_drawer # qiskit.visualization.pass\_manager\_drawer - + 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. diff --git a/docs/api/qiskit/dev/qiskit.visualization.plot_bloch_multivector.mdx b/docs/api/qiskit/dev/qiskit.visualization.plot_bloch_multivector.mdx index c38e5392e9a..40297cf0ce0 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.plot_bloch_multivector.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.plot_bloch_multivector.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_bloch_multivector # qiskit.visualization.plot\_bloch\_multivector - + 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. @@ -31,7 +31,7 @@ python_api_name: qiskit.visualization.plot_bloch_multivector **Return type** - [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.4)") + [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/_as_gen/matplotlib.figure.Figure.html#matplotlib.figure.Figure "(in Matplotlib v3.9.0)") **Raises** diff --git a/docs/api/qiskit/dev/qiskit.visualization.plot_bloch_vector.mdx b/docs/api/qiskit/dev/qiskit.visualization.plot_bloch_vector.mdx index 310e2d18a64..ac8bef71aee 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.plot_bloch_vector.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.plot_bloch_vector.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_bloch_vector # qiskit.visualization.plot\_bloch\_vector - + Plot the Bloch sphere. Plot a Bloch sphere with the specified coordinates, that can be given in both cartesian and spherical systems. @@ -19,7 +19,7 @@ python_api_name: qiskit.visualization.plot_bloch_vector * **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.4)")) – An Axes to use for rendering the bloch sphere + * **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.9.0)")) – 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. @@ -30,7 +30,7 @@ python_api_name: qiskit.visualization.plot_bloch_vector **Return type** - [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.4)") + [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/_as_gen/matplotlib.figure.Figure.html#matplotlib.figure.Figure "(in Matplotlib v3.9.0)") **Raises** diff --git a/docs/api/qiskit/dev/qiskit.visualization.plot_circuit_layout.mdx b/docs/api/qiskit/dev/qiskit.visualization.plot_circuit_layout.mdx index 5741b941f02..54a5ba361d8 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.plot_circuit_layout.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.plot_circuit_layout.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_circuit_layout # qiskit.visualization.plot\_circuit\_layout - + Plot the layout of a circuit transpiled for a given target backend. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.visualization.plot_coupling_map.mdx b/docs/api/qiskit/dev/qiskit.visualization.plot_coupling_map.mdx index 1b4cd718c4f..8312511a1a6 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.plot_coupling_map.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.plot_coupling_map.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_coupling_map # qiskit.visualization.plot\_coupling\_map - + Plots an arbitrary coupling map of qubits (embedded in a plane). **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.visualization.plot_distribution.mdx b/docs/api/qiskit/dev/qiskit.visualization.plot_distribution.mdx index c6e786ed320..ae2c6d3d4b2 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.plot_distribution.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.plot_distribution.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_distribution # qiskit.visualization.plot\_distribution - + Plot a distribution from input sampled data. **Parameters** @@ -24,7 +24,7 @@ python_api_name: qiskit.visualization.plot_distribution * **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.4)")) – 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. + * **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.9.0)")) – 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** diff --git a/docs/api/qiskit/dev/qiskit.visualization.plot_error_map.mdx b/docs/api/qiskit/dev/qiskit.visualization.plot_error_map.mdx index 5b04931d035..e9d5552b6b0 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.plot_error_map.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.plot_error_map.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_error_map # qiskit.visualization.plot\_error\_map - + Plots the error map of a given backend. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.visualization.plot_gate_map.mdx b/docs/api/qiskit/dev/qiskit.visualization.plot_gate_map.mdx index 23f87164ca3..8ff29d50774 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.plot_gate_map.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.plot_gate_map.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_gate_map # qiskit.visualization.plot\_gate\_map - + Plots the gate map of a device. **Parameters** diff --git a/docs/api/qiskit/dev/qiskit.visualization.plot_histogram.mdx b/docs/api/qiskit/dev/qiskit.visualization.plot_histogram.mdx index 2f77154a704..b81349596b8 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.plot_histogram.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.plot_histogram.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_histogram # qiskit.visualization.plot\_histogram - + Plot a histogram of input counts data. **Parameters** @@ -24,7 +24,7 @@ python_api_name: qiskit.visualization.plot_histogram * **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.4)")) – 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. + * **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.9.0)")) – 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** diff --git a/docs/api/qiskit/dev/qiskit.visualization.plot_state_city.mdx b/docs/api/qiskit/dev/qiskit.visualization.plot_state_city.mdx index a9e42e636e3..70faeb44452 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.plot_state_city.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.plot_state_city.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_state_city # qiskit.visualization.plot\_state\_city - + Plot the cityscape of quantum state. Plot two 3d bar graphs (two dimensional) of the real and imaginary part of the density matrix rho. @@ -22,8 +22,8 @@ python_api_name: qiskit.visualization.plot_state_city * **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.4)")) – 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.4)")) – 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. + * **ax\_real** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.9.0)")) – 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.9.0)")) – 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** @@ -31,7 +31,7 @@ python_api_name: qiskit.visualization.plot_state_city **Return type** - [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.4)") + [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/_as_gen/matplotlib.figure.Figure.html#matplotlib.figure.Figure "(in Matplotlib v3.9.0)") **Raises** diff --git a/docs/api/qiskit/dev/qiskit.visualization.plot_state_hinton.mdx b/docs/api/qiskit/dev/qiskit.visualization.plot_state_hinton.mdx index b306ef9f3f8..53bac3d07c2 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.plot_state_hinton.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.plot_state_hinton.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_state_hinton # qiskit.visualization.plot\_state\_hinton - + 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. @@ -21,8 +21,8 @@ python_api_name: qiskit.visualization.plot_state_hinton * **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.4)")) – 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.4)")) – 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\_real** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.9.0)")) – 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.9.0)")) – 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** @@ -30,7 +30,7 @@ python_api_name: qiskit.visualization.plot_state_hinton **Return type** - [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.4)") + [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/_as_gen/matplotlib.figure.Figure.html#matplotlib.figure.Figure "(in Matplotlib v3.9.0)") **Raises** diff --git a/docs/api/qiskit/dev/qiskit.visualization.plot_state_paulivec.mdx b/docs/api/qiskit/dev/qiskit.visualization.plot_state_paulivec.mdx index ba139f2aeb1..45250f948ff 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.plot_state_paulivec.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.plot_state_paulivec.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_state_paulivec # qiskit.visualization.plot\_state\_paulivec - + 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 @@ -28,7 +28,7 @@ $$ * **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.4)")) – 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. + * **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.9.0)")) – 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** @@ -36,7 +36,7 @@ $$ **Return type** - [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.4)") + [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/_as_gen/matplotlib.figure.Figure.html#matplotlib.figure.Figure "(in Matplotlib v3.9.0)") **Raises** diff --git a/docs/api/qiskit/dev/qiskit.visualization.plot_state_qsphere.mdx b/docs/api/qiskit/dev/qiskit.visualization.plot_state_qsphere.mdx index 23352ba517b..89d74b3ad23 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.plot_state_qsphere.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.plot_state_qsphere.mdx @@ -10,14 +10,14 @@ python_api_name: qiskit.visualization.plot_state_qsphere # qiskit.visualization.plot\_state\_qsphere - + 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.4)")) – 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. + * **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.9.0)")) – 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. @@ -28,7 +28,7 @@ python_api_name: qiskit.visualization.plot_state_qsphere **Return type** - [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.4)") + [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/_as_gen/matplotlib.figure.Figure.html#matplotlib.figure.Figure "(in Matplotlib v3.9.0)") **Raises** diff --git a/docs/api/qiskit/dev/qiskit.visualization.timeline_drawer.mdx b/docs/api/qiskit/dev/qiskit.visualization.timeline_drawer.mdx index d43b772af4f..a1ec7a8d59b 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.timeline_drawer.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.timeline_drawer.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.timeline_drawer # qiskit.visualization.timeline\_drawer - + Generate visualization data for scheduled circuit programs. diff --git a/docs/api/qiskit/dev/qiskit.visualization.visualize_transition.mdx b/docs/api/qiskit/dev/qiskit.visualization.visualize_transition.mdx index 6cbd3753000..feae2acbe9d 100644 --- a/docs/api/qiskit/dev/qiskit.visualization.visualize_transition.mdx +++ b/docs/api/qiskit/dev/qiskit.visualization.visualize_transition.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.visualize_transition # qiskit.visualization.visualize\_transition - + Creates animation showing transitions between states of a single qubit by applying quantum gates. **Parameters** diff --git a/docs/api/qiskit/dev/qpy.mdx b/docs/api/qiskit/dev/qpy.mdx index 8a66fecea68..2a7f4b7148c 100644 --- a/docs/api/qiskit/dev/qpy.mdx +++ b/docs/api/qiskit/dev/qpy.mdx @@ -57,7 +57,7 @@ and then loading that file will return a list with all the circuits ### load - + 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: @@ -102,7 +102,7 @@ and then loading that file will return a list with all the circuits ### dump - + 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. @@ -166,7 +166,7 @@ These functions will raise a custom subclass of [`QiskitError`](exceptions#qiski ### QpyError - + Errors raised by the qpy module. Set the error message. @@ -176,7 +176,7 @@ When a lower-than-maximum target QPY version is set for serialization, but the o ### UnsupportedFeatureForVersion - + QPY error raised when the target dump version is too low for a feature that is present in the object to be serialized. **Parameters** @@ -216,7 +216,7 @@ If a feature being loaded is deprecated in the corresponding qiskit release, QPY ### QPYLoadingDeprecatedFeatureWarning - + Visible deprecation warning for QPY loading functions without a stable point in the call stack. diff --git a/docs/api/qiskit/dev/quantum_info.mdx b/docs/api/qiskit/dev/quantum_info.mdx index 0d280ba4270..5aedbc2abeb 100644 --- a/docs/api/qiskit/dev/quantum_info.mdx +++ b/docs/api/qiskit/dev/quantum_info.mdx @@ -58,7 +58,7 @@ python_api_name: qiskit.quantum_info ### average\_gate\_fidelity - + Return the average gate fidelity of a noisy quantum channel. The average gate fidelity $F_{\text{ave}}$ is given by @@ -98,7 +98,7 @@ $$ ### process\_fidelity - + 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 @@ -145,7 +145,7 @@ $$ ### gate\_error - + Return the gate error of a noisy quantum channel. The gate error $E$ is given by the average gate infidelity @@ -180,7 +180,7 @@ $$ ### diamond\_norm - + 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]. @@ -218,7 +218,7 @@ $$ ### state\_fidelity - + Return the state fidelity between two quantum states. The state fidelity $F$ for density matrix input states $\rho_1, \rho_2$ is given by @@ -252,7 +252,7 @@ $$ ### purity - + Calculate the purity of a quantum state. The purity of a density matrix $\rho$ is @@ -281,7 +281,7 @@ $$ ### concurrence - + 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 @@ -321,7 +321,7 @@ $$ ### entropy - + Calculate the von-Neumann entropy of a quantum state. The entropy $S$ is given by @@ -350,7 +350,7 @@ $$ ### entanglement\_of\_formation - + 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. @@ -376,7 +376,7 @@ $$ ### mutual\_information - + Calculate the mutual information of a bipartite state. The mutual information $I$ is given by: @@ -414,7 +414,7 @@ $$ ### partial\_trace - + 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. @@ -439,7 +439,7 @@ $$ ### schmidt\_decomposition - + Return the Schmidt Decomposition of a pure quantum state. For an arbitrary bipartite state: @@ -487,7 +487,7 @@ $$ ### shannon\_entropy - + 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 @@ -514,7 +514,7 @@ $$ ### commutator - + Compute commutator of a and b. $$ @@ -537,7 +537,7 @@ $$ ### anti\_commutator - + Compute anti-commutator of a and b. $$ @@ -560,7 +560,7 @@ $$ ### double\_commutator - + Compute symmetric double commutator of a, b and c. See also Equation (13.6.18) in \[1]. @@ -607,7 +607,7 @@ $$ ### random\_statevector - + Generator a random Statevector. The statevector is sampled from the uniform distribution. This is the measure induced by the Haar measure on unitary matrices. @@ -632,7 +632,7 @@ $$ ### random\_density\_matrix - + Generator a random DensityMatrix. **Parameters** @@ -657,7 +657,7 @@ $$ ### random\_unitary - + Return a random unitary Operator. The operator is sampled from the unitary Haar measure. @@ -678,7 +678,7 @@ $$ ### random\_hermitian - + Return a random hermitian Operator. The operator is sampled from Gaussian Unitary Ensemble. @@ -700,7 +700,7 @@ $$ ### random\_pauli - + Return a random Pauli. **Parameters** @@ -720,7 +720,7 @@ $$ ### random\_clifford - + Return a random Clifford operator. The Clifford is sampled using the method of Reference \[1]. @@ -745,7 +745,7 @@ $$ ### random\_quantum\_channel - + 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. @@ -772,7 +772,7 @@ $$ ### random\_cnotdihedral - + Return a random CNOTDihedral element. **Parameters** @@ -791,7 +791,7 @@ $$ ### random\_pauli\_list - + Return a random PauliList. **Parameters** @@ -814,7 +814,7 @@ $$ ### hellinger\_distance - + Computes the Hellinger distance between two counts distributions. **Parameters** @@ -837,7 +837,7 @@ $$ ### hellinger\_fidelity - + 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]. diff --git a/docs/api/qiskit/dev/result.mdx b/docs/api/qiskit/dev/result.mdx index 0c65b7ac2c5..17dc59a33dc 100644 --- a/docs/api/qiskit/dev/result.mdx +++ b/docs/api/qiskit/dev/result.mdx @@ -30,7 +30,7 @@ python_api_name: qiskit.result ### marginal\_counts - + Marginalize counts from an experiment over some indices of interest. **Parameters** @@ -58,7 +58,7 @@ python_api_name: qiskit.result ### marginal\_distribution - + 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. @@ -85,7 +85,7 @@ python_api_name: qiskit.result ### marginal\_memory - + 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. @@ -123,7 +123,7 @@ python_api_name: qiskit.result ### sampled\_expectation\_value - + Computes expectation value from a sampled distribution Note that passing a raw dict requires bit-string keys. diff --git a/docs/api/qiskit/dev/scheduler.mdx b/docs/api/qiskit/dev/scheduler.mdx index 5e3cf919405..f83130bbd41 100644 --- a/docs/api/qiskit/dev/scheduler.mdx +++ b/docs/api/qiskit/dev/scheduler.mdx @@ -24,7 +24,7 @@ A circuit scheduler compiles a circuit program to a pulse program. ### ScheduleConfig - + Configuration for pulse scheduling. Container for information needed to schedule a QuantumCircuit into a pulse Schedule. @@ -38,7 +38,7 @@ A circuit scheduler compiles a circuit program to a pulse program. ### schedule\_circuit - + 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: @@ -70,7 +70,7 @@ A circuit scheduler compiles a circuit program to a pulse program. ### as\_soon\_as\_possible - + 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. @@ -92,7 +92,7 @@ A circuit scheduler compiles a circuit program to a pulse program. ### as\_late\_as\_possible - + 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. diff --git a/docs/api/qiskit/dev/synthesis.mdx b/docs/api/qiskit/dev/synthesis.mdx index f644d9ea739..be201f1a363 100644 --- a/docs/api/qiskit/dev/synthesis.mdx +++ b/docs/api/qiskit/dev/synthesis.mdx @@ -35,7 +35,7 @@ python_api_name: qiskit.synthesis ### synth\_cnot\_count\_full\_pmh - + 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 \times n$ matrix. @@ -64,7 +64,7 @@ python_api_name: qiskit.synthesis ### synth\_cnot\_depth\_line\_kms - + Synthesize linear reversible circuit for linear nearest-neighbor architectures using Kutin, Moulton, Smithline method. Synthesis algorithm for linear reversible circuits from \[1], section 7. This algorithm synthesizes any linear reversible circuit of $n$ qubits over a linear nearest-neighbor architecture using CX gates with depth at most $5n$. @@ -94,7 +94,7 @@ python_api_name: qiskit.synthesis ### synth\_cz\_depth\_line\_mr - + 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 [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate")s and phase gates ([`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate"), [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate") or [`ZGate`](qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate")). @@ -118,7 +118,7 @@ python_api_name: qiskit.synthesis ### synth\_cx\_cz\_depth\_line\_my - + 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** @@ -142,7 +142,7 @@ python_api_name: qiskit.synthesis ### synth\_cnot\_phase\_aam - + 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, `cx` gates are applied so that a designated target bit contains the (partial) parity $\chi_y(x)$ where $y_i = 1$ if and only if $y'_i = 1$ for all $y' \in S$. If $S$ contains a single element $\{y'\}$, then $y = y'$, and the target bit contains the value $\chi_{y'}(x)$ as desired. @@ -195,7 +195,7 @@ python_api_name: qiskit.synthesis ### synth\_permutation\_depth\_lnn\_kms - + Synthesize a permutation circuit for a linear nearest-neighbor architecture using the Kutin, Moulton, Smithline method. This is the permutation synthesis algorithm from \[1], section 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). @@ -219,7 +219,7 @@ python_api_name: qiskit.synthesis ### synth\_permutation\_basic - + 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. @@ -239,7 +239,7 @@ python_api_name: qiskit.synthesis ### synth\_permutation\_acg - + 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). @@ -266,7 +266,7 @@ python_api_name: qiskit.synthesis ### synth\_permutation\_reverse\_lnn\_kms - + Synthesize reverse permutation for linear nearest-neighbor architectures using Kutin, Moulton, Smithline method. Synthesis algorithm for reverse permutation from \[1], section 5. This algorithm synthesizes the reverse permutation on $n$ qubits over a linear nearest-neighbor architecture using CX gates with depth $2 * n + 2$. @@ -292,7 +292,7 @@ python_api_name: qiskit.synthesis ### synth\_clifford\_full - + Decompose a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") operator into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). For $N \leq 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]. @@ -319,7 +319,7 @@ python_api_name: qiskit.synthesis ### synth\_clifford\_ag - + Decompose a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") operator into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") based on Aaronson-Gottesman method \[1]. **Parameters** @@ -341,7 +341,7 @@ python_api_name: qiskit.synthesis ### synth\_clifford\_bm - + Optimal CX-cost decomposition of a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") operator on 2 qubits or 3 qubits into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") based on the Bravyi-Maslov method \[1]. **Parameters** @@ -367,7 +367,7 @@ python_api_name: qiskit.synthesis ### synth\_clifford\_greedy - + Decompose a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") operator into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") based on the greedy Clifford compiler that is described in Appendix A of Bravyi, Hu, Maslov and Shaydulin \[1]. This method typically yields better CX cost compared to the Aaronson-Gottesman method. @@ -397,7 +397,7 @@ python_api_name: qiskit.synthesis ### synth\_clifford\_layers - + Synthesis of a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") into layers, it provides a similar decomposition to the synthesis described in Lemma 8 of Bravyi and Maslov \[1]. For example, a 5-qubit Clifford circuit is decomposed into the following layers: @@ -442,7 +442,7 @@ python_api_name: qiskit.synthesis ### synth\_clifford\_depth\_lnn - + Synthesis of a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") into layers for linear-nearest neighbour connectivity. The depth of the synthesized n-qubit circuit is bounded by $7n+2$, which is not optimal. It should be replaced by a better algorithm that provides depth bounded by $7n-4$ \[3]. @@ -470,7 +470,7 @@ python_api_name: qiskit.synthesis ### synth\_cnotdihedral\_full - + Decompose a [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") element into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). For $N \leq 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]. @@ -495,7 +495,7 @@ python_api_name: qiskit.synthesis ### synth\_cnotdihedral\_two\_qubits - + Decompose a [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") element on a single qubit and two qubits into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). This decomposition has an optimal number of [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate")s. **Parameters** @@ -521,7 +521,7 @@ python_api_name: qiskit.synthesis ### synth\_cnotdihedral\_general - + Decompose a [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") element into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). Decompose a general [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") elements. The number of CX gates is not necessarily optimal. For a decomposition of a 1-qubit or 2-qubit element, call [`synth_cnotdihedral_two_qubits()`](#qiskit.synthesis.synth_cnotdihedral_two_qubits "qiskit.synthesis.synth_cnotdihedral_two_qubits"). @@ -551,7 +551,7 @@ python_api_name: qiskit.synthesis ### synth\_stabilizer\_layers - + Synthesis of a stabilizer state into layers. It provides a similar decomposition to the synthesis described in Lemma 8 of reference \[1], without the initial Hadamard-free sub-circuit which do not affect the stabilizer state. @@ -598,7 +598,7 @@ python_api_name: qiskit.synthesis ### synth\_stabilizer\_depth\_lnn - + Synthesis of an n-qubit stabilizer state for linear-nearest neighbour connectivity, in 2-qubit depth $2n+2$ and two distinct CX layers, using [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate")s and phase gates ([`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate"), [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate") or [`ZGate`](qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate")). **Parameters** @@ -621,7 +621,7 @@ python_api_name: qiskit.synthesis ### synth\_circuit\_from\_stabilizers - + Synthesis of a circuit that generates a state stabilized by the stabilizers using Gaussian elimination with Clifford gates. If the stabilizers are underconstrained, and `allow_underconstrained` is `True`, the circuit will output one of the states stabilized by the stabilizers. Based on stim implementation. **Parameters** @@ -657,7 +657,7 @@ python_api_name: qiskit.synthesis ### generate\_basic\_approximations - + Generates a list of `GateSequence`s with the gates in `basis_gates`. **Parameters** @@ -683,7 +683,7 @@ python_api_name: qiskit.synthesis ### synth\_qft\_line - + Synthesis of a QFT circuit for a linear nearest neighbor connectivity. Based on Fig 2.b in Fowler et al. \[1]. Note that this method *reverts* the order of qubits in the circuit, compared to the original [`QFT`](qiskit.circuit.library.QFT "qiskit.circuit.library.QFT") code. Hence, the default value of the `do_swaps` parameter is `True` since it produces a circuit with fewer CX gates. @@ -713,7 +713,7 @@ Decomposition of general $2^n \times 2^n$ unitary matrices for any number of qub ### qs\_decomposition - + Decomposes a unitary matrix into one and two qubit gates using Quantum Shannon Decomposition, This decomposition is described in Shende et al. \[1]. diff --git a/docs/api/qiskit/dev/transpiler.mdx b/docs/api/qiskit/dev/transpiler.mdx index 4124b41fb20..7a87a4485db 100644 --- a/docs/api/qiskit/dev/transpiler.mdx +++ b/docs/api/qiskit/dev/transpiler.mdx @@ -937,7 +937,7 @@ See [https://arxiv.org/abs/2102.01682](https://arxiv.org/abs/2102.01682) for mor #### TranspilerError - + Exceptions raised during transpilation. Set the error message. @@ -945,7 +945,7 @@ See [https://arxiv.org/abs/2102.01682](https://arxiv.org/abs/2102.01682) for mor #### TranspilerAccessError - + DEPRECATED: Exception of access error in the transpiler passes. Set the error message. @@ -953,7 +953,7 @@ See [https://arxiv.org/abs/2102.01682](https://arxiv.org/abs/2102.01682) for mor #### CouplingError - + Base class for errors raised by the coupling graph object. Set the error message. @@ -961,7 +961,7 @@ See [https://arxiv.org/abs/2102.01682](https://arxiv.org/abs/2102.01682) for mor #### LayoutError - + Errors raised by the layout object. Set the error message. @@ -969,7 +969,7 @@ See [https://arxiv.org/abs/2102.01682](https://arxiv.org/abs/2102.01682) for mor #### CircuitTooWideForTarget - + Error raised if the circuit is too wide for the target. Set the error message. @@ -977,7 +977,7 @@ See [https://arxiv.org/abs/2102.01682](https://arxiv.org/abs/2102.01682) for mor #### InvalidLayoutError - + Error raised when a user provided layout is invalid. Set the error message. diff --git a/docs/api/qiskit/dev/transpiler_passes.mdx b/docs/api/qiskit/dev/transpiler_passes.mdx index 6b3d78bee8d..922ed0283cd 100644 --- a/docs/api/qiskit/dev/transpiler_passes.mdx +++ b/docs/api/qiskit/dev/transpiler_passes.mdx @@ -96,7 +96,7 @@ python_api_name: qiskit.transpiler.passes ### rzx\_templates - + Convenience function to get the cost\_dict and templates for template matching. **Parameters** diff --git a/docs/api/qiskit/dev/transpiler_plugins.mdx b/docs/api/qiskit/dev/transpiler_plugins.mdx index 2e6d9df068f..e94e9487cb2 100644 --- a/docs/api/qiskit/dev/transpiler_plugins.mdx +++ b/docs/api/qiskit/dev/transpiler_plugins.mdx @@ -97,7 +97,7 @@ There isn’t a limit to the number of plugins a single package can include as l ### list\_stage\_plugins - + Get a list of installed plugins for a stage. **Parameters** @@ -119,7 +119,7 @@ There isn’t a limit to the number of plugins a single package can include as l ### passmanager\_stage\_plugins - + 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: diff --git a/docs/api/qiskit/dev/transpiler_preset.mdx b/docs/api/qiskit/dev/transpiler_preset.mdx index 0993d07eabb..90a567e66cc 100644 --- a/docs/api/qiskit/dev/transpiler_preset.mdx +++ b/docs/api/qiskit/dev/transpiler_preset.mdx @@ -26,7 +26,7 @@ This module contains functions for generating the preset pass managers for the t ### generate\_preset\_pass\_manager - + 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 @@ -97,7 +97,7 @@ This module contains functions for generating the preset pass managers for the t ### level\_0\_pass\_manager - + 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. @@ -123,7 +123,7 @@ This module contains functions for generating the preset pass managers for the t ### level\_1\_pass\_manager - + 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. @@ -147,7 +147,7 @@ This module contains functions for generating the preset pass managers for the t ### level\_2\_pass\_manager - + 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. @@ -173,7 +173,7 @@ This module contains functions for generating the preset pass managers for the t ### level\_3\_pass\_manager - + 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. @@ -203,7 +203,7 @@ This module contains functions for generating the preset pass managers for the t ### generate\_control\_flow\_options\_check - + 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** @@ -217,13 +217,13 @@ This module contains functions for generating the preset pass managers for the t ### generate\_error\_on\_control\_flow - + Get a pass manager that always raises an error if control flow is present in a given circuit. ### generate\_unroll\_3q - + Generate an unroll >3q [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") **Parameters** @@ -246,7 +246,7 @@ This module contains functions for generating the preset pass managers for the t ### generate\_embed\_passmanager - + 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 @@ -268,7 +268,7 @@ This module contains functions for generating the preset pass managers for the t ### generate\_routing\_passmanager - + Generate a routing [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") **Parameters** @@ -294,7 +294,7 @@ This module contains functions for generating the preset pass managers for the t ### generate\_pre\_op\_passmanager - + 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 @@ -316,7 +316,7 @@ This module contains functions for generating the preset pass managers for the t ### generate\_translation\_passmanager - + Generate a basis translation [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") **Parameters** @@ -346,7 +346,7 @@ This module contains functions for generating the preset pass managers for the t ### generate\_scheduling - + Generate a post optimization scheduling [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") **Parameters** diff --git a/docs/api/qiskit/dev/utils.mdx b/docs/api/qiskit/dev/utils.mdx index f7f3de13a6e..c08d354b0ed 100644 --- a/docs/api/qiskit/dev/utils.mdx +++ b/docs/api/qiskit/dev/utils.mdx @@ -22,7 +22,7 @@ python_api_name: qiskit.utils ### add\_deprecation\_to\_docstring - + Dynamically insert the deprecation message into `func`’s docstring. **Parameters** @@ -35,7 +35,7 @@ python_api_name: qiskit.utils ### deprecate\_arg - + 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. @@ -63,7 +63,7 @@ python_api_name: qiskit.utils ### deprecate\_arguments - + Deprecated. Instead, use @deprecate\_arg. **Parameters** @@ -83,7 +83,7 @@ python_api_name: qiskit.utils ### deprecate\_func - + Decorator to indicate a function has been deprecated. It should be placed beneath other decorators like @staticmethod and property decorators. @@ -110,7 +110,7 @@ python_api_name: qiskit.utils ### deprecate\_function - + Deprecated. Instead, use @deprecate\_func. **Parameters** @@ -133,7 +133,7 @@ python_api_name: qiskit.utils ### apply\_prefix - + Given a SI unit prefix and value, apply the prefix to convert to standard SI unit. **Parameters** @@ -164,7 +164,7 @@ python_api_name: qiskit.utils ### detach\_prefix - + 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). @@ -208,7 +208,7 @@ python_api_name: qiskit.utils ### wrap\_method - + 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. @@ -231,7 +231,7 @@ python_api_name: qiskit.utils ### local\_hardware\_info - + 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. @@ -247,22 +247,22 @@ python_api_name: qiskit.utils ### is\_main\_process - + Checks whether the current process is the main one -A helper function for calling a custom function with python [`ProcessPoolExecutor`](https://docs.python.org/3/library/concurrent.futures.html#concurrent.futures.ProcessPoolExecutor "(in Python v3.12)"). Tasks can be executed in parallel using this function. +A helper function for calling a custom function with Python [`ProcessPoolExecutor`](https://docs.python.org/3/library/concurrent.futures.html#concurrent.futures.ProcessPoolExecutor "(in Python v3.12)"). Tasks can be executed in parallel using this function. ### parallel\_map - + 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. + This will parallelise the results if the number of `values` is greater than one, and the current system configuration permits parallelization. **Parameters** @@ -274,11 +274,7 @@ A helper function for calling a custom function with python [`ProcessPoolExecuto **Returns** - **The result list contains the value of** - - **`task(value, *task_args, **task_kwargs)` for** - - each value in `values`. + The result list contains the value of `task(value, *task_args, **task_kwargs)` for each value in `values`. **Return type** @@ -365,7 +361,7 @@ from qiskit.utils import LazyImportTester #### LazyDependencyManager - + 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. @@ -405,7 +401,7 @@ from qiskit.utils import LazyImportTester ##### \_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** @@ -421,7 +417,7 @@ from qiskit.utils import LazyImportTester ##### require\_in\_call - + Create a decorator for callables that requires that the dependency is available when the decorated function or method is called. **Parameters** @@ -439,7 +435,7 @@ from qiskit.utils import LazyImportTester ##### require\_in\_instance - + 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** @@ -457,7 +453,7 @@ from qiskit.utils import LazyImportTester ##### require\_now - + Eagerly attempt to import the dependencies in this object, and raise an exception if they cannot be imported. **Parameters** @@ -472,7 +468,7 @@ from qiskit.utils import LazyImportTester #### LazyImportTester - + 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** @@ -486,7 +482,7 @@ from qiskit.utils import LazyImportTester #### LazySubprocessTester - + 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** diff --git a/docs/api/qiskit/dev/visualization.mdx b/docs/api/qiskit/dev/visualization.mdx index 517713277ad..8edd3347460 100644 --- a/docs/api/qiskit/dev/visualization.mdx +++ b/docs/api/qiskit/dev/visualization.mdx @@ -225,7 +225,7 @@ You can find code examples for each visualization functions on the individual fu ### VisualizationError - + For visualization specific errors. Set the error message. diff --git a/docs/api/qiskit/exceptions.mdx b/docs/api/qiskit/exceptions.mdx index 331e9146494..c03e83fcf6d 100644 --- a/docs/api/qiskit/exceptions.mdx +++ b/docs/api/qiskit/exceptions.mdx @@ -24,7 +24,7 @@ All Qiskit-related exceptions raised by Qiskit are subclasses of the base: ### QiskitError - + Base class for errors raised by Qiskit. Set the error message. @@ -40,7 +40,7 @@ Qiskit has several optional features that depend on other packages that are not ### MissingOptionalLibraryError - + 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 @@ -50,7 +50,7 @@ Two more uncommon errors relate to failures in reading user-configuration files, ### QiskitUserConfigError - + Raised when an error is encountered reading a user config file. Set the error message. @@ -58,7 +58,7 @@ Two more uncommon errors relate to failures in reading user-configuration files, ### InvalidFileError - + Raised when the file provided is not valid for the specific task. Set the error message. @@ -70,7 +70,7 @@ Some particular features of Qiskit may raise custom warnings. In general, Qiskit ### QiskitWarning - + Common subclass of warnings for Qiskit-specific warnings being raised. @@ -78,7 +78,7 @@ Related to [`MissingOptionalLibraryError`](#qiskit.exceptions.MissingOptionalLib ### OptionalDependencyImportWarning - + Raised when an optional library raises errors during its import. @@ -90,7 +90,7 @@ When experimental features are being used, Qiskit will raise [`ExperimentalWarni ### ExperimentalWarning - + Raised when an experimental feature is being used. diff --git a/docs/api/qiskit/index.mdx b/docs/api/qiskit/index.mdx index 7e20f134155..b46c80cebc6 100644 --- a/docs/api/qiskit/index.mdx +++ b/docs/api/qiskit/index.mdx @@ -10,38 +10,61 @@ python_api_name: qiskit # API Reference -* [Quantum Circuits (`qiskit.circuit`)](circuit) -* [Circuit Library (`qiskit.circuit.library`)](circuit_library) +Circuit construction: + +* [Quantum circuit model (`qiskit.circuit`)](circuit) +* [`QuantumCircuit` class](qiskit.circuit.QuantumCircuit) * [Classical expressions (`qiskit.circuit.classical`)](circuit_classical) -* [Singleton instructions (`qiskit.circuit.singleton`)](circuit_singleton) -* [Compilation Routines (`qiskit.compiler`)](compiler) -* [Visualizations (`qiskit.visualization`)](visualization) * [ClassicalFunction compiler (`qiskit.circuit.classicalfunction`)](classicalfunction) +* [Circuit Library (`qiskit.circuit.library`)](circuit_library) +* [Singleton instructions (`qiskit.circuit.singleton`)](circuit_singleton) + +Quantum information: + +* [Quantum Information (`qiskit.quantum_info`)](quantum_info) + +Transpilation: + * [Circuit Converters (`qiskit.converters`)](converters) -* [Circuit and Schedule Assembler (`qiskit.assembler`)](assembler) * [DAG Circuits (`qiskit.dagcircuit`)](dagcircuit) * [Passmanager (`qiskit.passmanager`)](passmanager) +* [Circuit Synthesis (`qiskit.synthesis`)](synthesis) +* [Approximate Quantum Compiler (`qiskit.synthesis.unitary.aqc`)](qiskit.synthesis.unitary.aqc) +* [Transpiler (`qiskit.transpiler`)](transpiler) +* [Transpiler Passes (`qiskit.transpiler.passes`)](transpiler_passes) +* [Synthesis Plugins (`qiskit.transpiler.passes.synthesis.plugin`)](transpiler_synthesis_plugins) +* [Preset Passmanagers (`qiskit.transpiler.preset_passmanagers`)](transpiler_preset) +* [Transpiler Stage Plugin Interface (`qiskit.transpiler.preset_passmanagers.plugin`)](transpiler_plugins) + +Primitives and providers: + +* [Primitives (`qiskit.primitives`)](primitives) * [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) * [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) + +Results and visualizations: + +* [Experiment Results (`qiskit.result`)](result) +* [Visualizations (`qiskit.visualization`)](visualization) + +Serialization: + * [OpenQASM 2 (`qiskit.qasm2`)](qasm2) * [OpenQASM 3 (`qiskit.qasm3`)](qasm3) -* [Qobj (`qiskit.qobj`)](qobj) * [QPY serialization (`qiskit.qpy`)](qpy) -* [Quantum Information (`qiskit.quantum_info`)](quantum_info) -* [Experiment Results (`qiskit.result`)](result) -* [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) -* [Utilities (`qiskit.utils`)](utils) + +Pulse-level programming: + +* [Pulse (`qiskit.pulse`)](pulse) +* [Circuit Scheduler (`qiskit.scheduler`)](scheduler) + +Other: + +* [Circuit and Schedule Assembler (`qiskit.assembler`)](assembler) +* [Compilation Routines (`qiskit.compiler`)](compiler) * [Top-level exceptions (`qiskit.exceptions`)](exceptions) +* [Qobj (`qiskit.qobj`)](qobj) +* [Utilities (`qiskit.utils`)](utils) diff --git a/docs/api/qiskit/passmanager.mdx b/docs/api/qiskit/passmanager.mdx index 1f11d938c56..f9c7d4bddd6 100644 --- a/docs/api/qiskit/passmanager.mdx +++ b/docs/api/qiskit/passmanager.mdx @@ -162,7 +162,7 @@ With the pass manager framework, a developer can flexibly customize the optimiza #### PassManagerError - + Pass manager error. Set the error message. diff --git a/docs/api/qiskit/primitives.mdx b/docs/api/qiskit/primitives.mdx index c6dd3a4c47c..2837c8f0184 100644 --- a/docs/api/qiskit/primitives.mdx +++ b/docs/api/qiskit/primitives.mdx @@ -63,17 +63,17 @@ theta3 = [1, 2, 3, 4, 5, 6] estimator = Estimator() # calculate [ ] -job = estimator.run([(psi1, hamiltonian1, [theta1])]) +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}")) +print(f"The primitive-job finished with result {job_result}") # calculate [ [, # ], # [] ] job2 = estimator.run( [ - (psi1, [hamiltonian1, hamiltonian3], [theta1, theta3]), - (psi2, hamiltonian2, theta2) + (psi1, [H1, H3], [theta1, theta3]), + (psi2, H2, theta2) ], precision=0.01 ) @@ -304,12 +304,13 @@ The formal distinction between the Primitives V1 and V2 APIs are the base classe ## Primitives API -### Primitives V2 +### Estimator V2 | | | | ----------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------ | | [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2")() | Estimator V2 base class. | | [`StatevectorEstimator`](qiskit.primitives.StatevectorEstimator "qiskit.primitives.StatevectorEstimator")(\*\[, default\_precision, ...]) | Simple implementation of [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") with full state vector simulation. | +| [`BackendEstimatorV2`](qiskit.primitives.BackendEstimatorV2 "qiskit.primitives.BackendEstimatorV2")(\*, backend\[, options]) | Evaluates expectation values for provided quantum circuit and observable combinations | ### Sampler V2 @@ -317,17 +318,20 @@ The formal distinction between the Primitives V1 and V2 APIs are the base classe | -------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------- | | [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2")() | Sampler V2 base class. | | [`StatevectorSampler`](qiskit.primitives.StatevectorSampler "qiskit.primitives.StatevectorSampler")(\*\[, default\_shots, seed]) | Simple implementation of [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") using full state vector simulation. | +| [`BackendSamplerV2`](qiskit.primitives.BackendSamplerV2 "qiskit.primitives.BackendSamplerV2")(\*, backend\[, options]) | Evaluates bitstrings for provided quantum circuits | ### Results V2 | | | | --------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------- | | [`BitArray`](qiskit.primitives.BitArray "qiskit.primitives.BitArray")(array, num\_bits) | Stores an array of bit values. | -| [`DataBin`](qiskit.primitives.DataBin "qiskit.primitives.DataBin")() | Base class for data bin containers. | +| [`DataBin`](qiskit.primitives.DataBin "qiskit.primitives.DataBin")(\*\[, shape]) | Namespace for storing data. | | [`PrimitiveResult`](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")(pub\_results\[, metadata]) | A container for multiple pub results and global metadata. | | [`PubResult`](qiskit.primitives.PubResult "qiskit.primitives.PubResult")(data\[, metadata]) | Result of Primitive Unified Bloc. | +| [`SamplerPubResult`](qiskit.primitives.SamplerPubResult "qiskit.primitives.SamplerPubResult")(data\[, metadata]) | Result of Sampler Pub. | | [`BasePrimitiveJob`](qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob")(job\_id, \*\*kwargs) | Primitive job abstract base class. | | [`PrimitiveJob`](qiskit.primitives.PrimitiveJob "qiskit.primitives.PrimitiveJob")(function, \*args, \*\*kwargs) | Primitive job class for the reference implementations of Primitives. | +| [`Shaped`](qiskit.primitives.Shaped "qiskit.primitives.Shaped")(\*args, \*\*kwargs) | Protocol that defines what it means to be a shaped object. | ### Estimator V1 diff --git a/docs/api/qiskit/providers.mdx b/docs/api/qiskit/providers.mdx index 69149be6712..ea9a6921126 100644 --- a/docs/api/qiskit/providers.mdx +++ b/docs/api/qiskit/providers.mdx @@ -18,7 +18,7 @@ python_api_name: qiskit.providers `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. +This module contains the classes used to build external providers for Qiskit. A provider is anything that provides an external service to Qiskit. 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 Qiskit. ## Version Support @@ -26,13 +26,13 @@ Each providers interface abstract class is individually versioned. When we need ### 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. +Each minor version release of `qiskit` **may** increment the version of any backend 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. +To enable providers to have time to adjust to changes in this interface Qiskit 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. Qiskit 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.github.io/qiskit-aer/stubs/qiskit_aer.AerSimulator.html#qiskit_aer.AerSimulator "(in Qiskit Aer v0.14.0)") 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). +It’s worth pointing out that Qiskit’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 Qiskit’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.github.io/qiskit-aer/stubs/qiskit_aer.AerSimulator.html#qiskit_aer.AerSimulator "(in Qiskit Aer v0.14.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 Qiskit, 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 @@ -77,7 +77,7 @@ It’s worth pointing out that Terra’s version support policy doesn’t mean p #### QiskitBackendNotFoundError - + Base class for errors raised while looking for a backend. Set the error message. @@ -85,7 +85,7 @@ It’s worth pointing out that Terra’s version support policy doesn’t mean p #### BackendPropertyError - + Base class for errors raised while looking for a backend property. Set the error message. @@ -93,7 +93,7 @@ It’s worth pointing out that Terra’s version support policy doesn’t mean p #### JobError - + Base class for errors raised by Jobs. Set the error message. @@ -101,7 +101,7 @@ It’s worth pointing out that Terra’s version support policy doesn’t mean p #### JobTimeoutError - + Base class for timeout errors raised by jobs. Set the error message. @@ -109,17 +109,17 @@ It’s worth pointing out that Terra’s version support policy doesn’t mean p #### BackendConfigurationError - + Base class for errors raised by the BackendConfiguration. Set the error message. -# Writing a New Provider +## Writing a New Backend -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 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: +If you have a quantum device or simulator that you would like to integrate with Qiskit you will need to write a backend. A provider is a collection of backends and will provide Qiskit 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 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 `Provider` class 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. > @@ -131,17 +131,16 @@ For a simple example of a provider, see the [qiskit-aqt-provider](https://github -## 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): +class MyProvider: def __init__(self, token=None): super().__init__() @@ -159,7 +158,7 @@ Ensure that any necessary information for authentication (if required) are prese -## Backend +### 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: @@ -229,7 +228,9 @@ class Mybackend(Backend): return MyJob(self. job_handle, job_json, circuit) ``` -### Transpiler Interface + + +### Backend’s 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. @@ -331,7 +332,37 @@ This snippet of a backend implementation will now have the [`transpile()`](compi 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 + + +#### Real-time variables + +The transpiler will automatically handle real-time typed classical variables (see [`qiskit.circuit.classical`](circuit_classical#module-qiskit.circuit.classical "qiskit.circuit.classical")) and treat the [`Store`](circuit#qiskit.circuit.Store "qiskit.circuit.Store") instruction as a built-in “directive”, similar to [`Barrier`](circuit#qiskit.circuit.Barrier "qiskit.circuit.Barrier"). No special handling from backends is necessary to permit this. + +If your backend is *unable* to handle classical variables and storage, we recommend that you comment on this in your documentation, and insert a check into your [`run()`](qiskit.providers.BackendV2#run "qiskit.providers.BackendV2.run") method (see [Backend.run Method](#providers-guide-backend-run)) to eagerly reject circuits containing them. You can examine [`QuantumCircuit.num_vars`](qiskit.circuit.QuantumCircuit#num_vars "qiskit.circuit.QuantumCircuit.num_vars") for the presence of variables at the top level. If you accept [control-flow operations](circuit#circuit-control-flow-repr), you might need to recursively search the internal [`blocks`](qiskit.circuit.ControlFlowOp#blocks "qiskit.circuit.ControlFlowOp.blocks") of each for scope-local variables with [`QuantumCircuit.num_declared_vars`](qiskit.circuit.QuantumCircuit#num_declared_vars "qiskit.circuit.QuantumCircuit.num_declared_vars"). + +For example, a function to check for the presence of any manual storage locations, or manual stores to memory: + +```python +from qiskit.circuit import Store, ControlFlowOp, QuantumCircuit + +def has_realtime_logic(circuit: QuantumCircuit) -> bool: + if circuit.num_vars: + return True + for instruction in circuit.data: + if isinstance(instruction.operation, Store): + return True + elif isinstance(instruction.operation, ControlFlowOp): + for block in instruction.operation.blocks: + if has_realtime_logic(block): + return True + return False +``` + + + + + +### Backend.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 IBM backends from the `qiskit-ibm-provider` package this involves converting from a quantum circuit and options into a [`qpy`](qpy#module-qiskit.qpy "qiskit.qpy") payload embedded in JSON 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. @@ -353,9 +384,7 @@ def run(self, circuits. **kwargs): return MyJob(self. job_handle, job_json, circuit) ``` - - -### Options +### Backend 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: @@ -373,9 +402,9 @@ 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 +### 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. @@ -460,17 +489,13 @@ class MySyncJob(Job): return JobStatus.DONE ``` -## Primitives +### 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` and `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 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 +## Migrating from BackendV1 to 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"). @@ -492,8 +517,8 @@ Below is a table of example access patterns in [`BackendV1`](qiskit.providers.Ba | `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"). | +| `backend.properties().readout_error(0)` | `backend.target["measure"][(0,)].error` | In [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") the error rate for the `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` 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/providers_basic_provider.mdx b/docs/api/qiskit/providers_basic_provider.mdx index eb5dc6f06c2..4054b9af33a 100644 --- a/docs/api/qiskit/providers_basic_provider.mdx +++ b/docs/api/qiskit/providers_basic_provider.mdx @@ -26,27 +26,12 @@ 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. | +## Classes + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------- | +| [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator")(\[provider, target]) | Python implementation of a basic (non-efficient) quantum simulator. | +| [`BasicProvider`](qiskit.providers.basic_provider.BasicProvider "qiskit.providers.basic_provider.BasicProvider")() | Provider for test simulators. | +| [`BasicProviderJob`](qiskit.providers.basic_provider.BasicProviderJob "qiskit.providers.basic_provider.BasicProviderJob")(backend, job\_id, result) | BasicProviderJob class. | +| [`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/providers_fake_provider.mdx b/docs/api/qiskit/providers_fake_provider.mdx index 1b08f7f6f80..9429caec159 100644 --- a/docs/api/qiskit/providers_fake_provider.mdx +++ b/docs/api/qiskit/providers_fake_provider.mdx @@ -22,7 +22,7 @@ python_api_name: qiskit.providers.fake_provider The fake provider module in Qiskit contains fake (simulated) backend classes useful for testing the transpiler and other backend-facing functionality. -## Example Usage +### Example Usage Here is an example of using a simulated backend for transpilation and running. @@ -83,7 +83,7 @@ The V1 fake backends are based on a set of base classes: ### FakeBackend - + This is a dummy backend just for testing purposes. FakeBackend initializer. @@ -96,7 +96,7 @@ The V1 fake backends are based on a set of base classes: ### FakeQasmBackend - + A fake OpenQASM backend. FakeBackend initializer. @@ -109,7 +109,7 @@ The V1 fake backends are based on a set of base classes: ### FakePulseBackend - + A fake pulse backend. FakeBackend initializer. diff --git a/docs/api/qiskit/providers_models.mdx b/docs/api/qiskit/providers_models.mdx index d707ddeb624..3f4f7b13266 100644 --- a/docs/api/qiskit/providers_models.mdx +++ b/docs/api/qiskit/providers_models.mdx @@ -20,7 +20,7 @@ python_api_name: qiskit.providers.models Qiskit schema-conformant objects used by the backends and providers. -## Backend Objects +## Classes | | | | -------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------- | diff --git a/docs/api/qiskit/pulse.mdx b/docs/api/qiskit/pulse.mdx index 8b6fb27d092..5916960cc72 100644 --- a/docs/api/qiskit/pulse.mdx +++ b/docs/api/qiskit/pulse.mdx @@ -72,7 +72,7 @@ These are all instances of the same base class: ### Instruction - + The smallest schedulable unit: a single instruction. It has a fixed duration and specified channels. Instruction initializer. @@ -165,7 +165,7 @@ All channels are children of the same abstract base class: ### Channel - + 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. @@ -220,7 +220,7 @@ These are all subtypes of the abstract base class [`AlignmentKind`](#qiskit.puls #### AlignmentKind - + An abstract class for schedule alignment. Create new context. @@ -234,7 +234,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### add\_implicit\_acquires - + Return a new schedule with implicit acquires from the measurement mapping replaced by explicit ones. @@ -257,7 +257,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### align\_measures - + 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. @@ -324,7 +324,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### block\_to\_schedule - + Convert `ScheduleBlock` to `Schedule`. **Parameters** @@ -351,7 +351,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### compress\_pulses - + Optimization pass to replace identical pulses. **Parameters** @@ -369,7 +369,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### flatten - + Flatten (inline) any called nodes into a Schedule tree with no nested children. **Parameters** @@ -391,7 +391,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### inline\_subroutines - + 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. @@ -415,7 +415,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### pad - + Pad the input Schedule with `Delay``s on all unoccupied timeslots until ``schedule.duration` or `until` if not `None`. **Parameters** @@ -441,7 +441,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### remove\_directives - + Remove directives. **Parameters** @@ -459,7 +459,7 @@ The canonicalization transforms convert schedules to a form amenable for executi #### remove\_trivial\_barriers - + Remove trivial barriers with 0 or 1 channels. **Parameters** @@ -483,7 +483,7 @@ The DAG transforms create DAG representation of input program. This can be used #### block\_to\_dag - + 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. @@ -541,7 +541,7 @@ A sequence of transformations to generate a target code. #### target\_qobj\_transform - + A basic pulse program transformation for OpenPulse API execution. **Parameters** @@ -758,7 +758,7 @@ The above is just a small taste of what is possible with the builder. See the re ### build - + Create a context manager for launching the imperative pulse builder DSL. To enter a building context and starting building a pulse program: @@ -818,7 +818,7 @@ DriveChannel(0) #### acquire\_channel - + Return `AcquireChannel` for `qubit` on the active builder backend. Examples: @@ -844,7 +844,7 @@ DriveChannel(0) #### control\_channels - + 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. @@ -879,7 +879,7 @@ DriveChannel(0) #### drive\_channel - + Return `DriveChannel` for `qubit` on the active builder backend. Examples: @@ -905,7 +905,7 @@ DriveChannel(0) #### measure\_channel - + Return `MeasureChannel` for `qubit` on the active builder backend. Examples: @@ -964,7 +964,7 @@ drive_sched.draw() #### acquire - + Acquire for a `duration` on a `channel` and store the result in a `register`. Examples: @@ -1001,7 +1001,7 @@ drive_sched.draw() #### barrier - + 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: @@ -1068,7 +1068,7 @@ drive_sched.draw() #### call - + Call the subroutine within the currently active builder context with arbitrary parameters which will be assigned to the target program. @@ -1237,7 +1237,7 @@ drive_sched.draw() #### delay - + Delay on a `channel` for a `duration`. Examples: @@ -1260,7 +1260,7 @@ drive_sched.draw() #### play - + Play a `pulse` on a `channel`. Examples: @@ -1283,7 +1283,7 @@ drive_sched.draw() #### reference - + 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. @@ -1308,7 +1308,7 @@ drive_sched.draw() #### set\_frequency - + Set the `frequency` of a pulse `channel`. Examples: @@ -1331,7 +1331,7 @@ drive_sched.draw() #### set\_phase - + Set the `phase` of a pulse `channel`. Examples: @@ -1356,7 +1356,7 @@ drive_sched.draw() #### shift\_frequency - + Shift the `frequency` of a pulse `channel`. Examples: @@ -1379,7 +1379,7 @@ drive_sched.draw() #### shift\_phase - + Shift the `phase` of a pulse `channel`. Examples: @@ -1404,7 +1404,7 @@ drive_sched.draw() #### snapshot - + Simulator snapshot. Examples: @@ -1747,7 +1747,7 @@ MemorySlot(0) #### measure - + 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"). @@ -1802,7 +1802,7 @@ MemorySlot(0) #### measure\_all - + 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. @@ -1835,7 +1835,7 @@ MemorySlot(0) #### delay\_qubits - + Insert delays on all the `channels.Channel`s that correspond to the input `qubits` at the same time. Examples: @@ -1892,7 +1892,7 @@ There are 1e-06 seconds in 4500 samples. #### active\_backend - + Get the backend of the currently active builder context. **Returns** @@ -1912,7 +1912,7 @@ There are 1e-06 seconds in 4500 samples. #### num\_qubits - + Return number of qubits in the currently active backend. Examples: @@ -1942,7 +1942,7 @@ There are 1e-06 seconds in 4500 samples. #### qubit\_channels - + Returns the set of channels associated with a qubit. Examples: @@ -1976,7 +1976,7 @@ There are 1e-06 seconds in 4500 samples. #### samples\_to\_seconds - + Obtain the time in seconds that will elapse for the input number of samples on the active backend. **Parameters** @@ -1994,7 +1994,7 @@ There are 1e-06 seconds in 4500 samples. #### seconds\_to\_samples - + Obtain the number of samples that will elapse in `seconds` on the active backend. Rounds down. @@ -2022,7 +2022,7 @@ There are 1e-06 seconds in 4500 samples. ### PulseError - + Errors raised by the pulse module. Set the error message. @@ -2030,7 +2030,7 @@ There are 1e-06 seconds in 4500 samples. ### BackendNotSet - + Raised if the builder context does not have a backend. Set the error message. @@ -2038,7 +2038,7 @@ There are 1e-06 seconds in 4500 samples. ### NoActiveBuilder - + Raised if no builder context is active. Set the error message. @@ -2046,7 +2046,7 @@ There are 1e-06 seconds in 4500 samples. ### UnassignedDurationError - + Raised if instruction duration is unassigned. Set the error message. @@ -2054,7 +2054,7 @@ There are 1e-06 seconds in 4500 samples. ### UnassignedReferenceError - + Raised if subroutine is unassigned. Set the error message. diff --git a/docs/api/qiskit/qasm2.mdx b/docs/api/qiskit/qasm2.mdx index dea008cc504..a7a1f6f53c0 100644 --- a/docs/api/qiskit/qasm2.mdx +++ b/docs/api/qiskit/qasm2.mdx @@ -32,7 +32,7 @@ This module contains two public functions, both of which create a [`QuantumCircu ### load - + 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** @@ -55,7 +55,7 @@ This module contains two public functions, both of which create a [`QuantumCircu ### loads - + Parse an OpenQASM 2 program from a string into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). **Parameters** @@ -85,7 +85,7 @@ You can extend the quantum components of the OpenQASM 2 language by passing an i #### CustomInstruction - + 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. @@ -123,7 +123,7 @@ Similar to other serialisation modules in Python, this module offers two public ### dump - + Dump a circuit as an OpenQASM 2 program to a file or stream. **Parameters** @@ -138,7 +138,7 @@ Similar to other serialisation modules in Python, this module offers two public ### dumps - + Export a circuit to an OpenQASM 2 program in a string. **Parameters** @@ -164,7 +164,7 @@ This module defines a generic error type that derives from [`QiskitError`](excep ### QASM2Error - + A general error raised by the OpenQASM 2 interoperation layer. Set the error message. @@ -174,7 +174,7 @@ In cases where the lexer or parser fails due to an invalid OpenQASM 2 file, the ### QASM2ParseError - + An error raised because of a failure to parse an OpenQASM 2 file. Set the error message. @@ -184,7 +184,7 @@ When the exporters fail to export a circuit, likely because it has structure tha ### QASM2ExportError - + An error raised because of a failure to convert a Qiskit object to an OpenQASM 2 form. Set the error message. @@ -474,7 +474,7 @@ In particular, in the legacy importers: 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. +* if *any* `opaque` or `gate` definition was given for the name `delay`, they attempt to output a [`Delay`](circuit#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. diff --git a/docs/api/qiskit/qasm3.mdx b/docs/api/qiskit/qasm3.mdx index 786484620ca..c57d0126342 100644 --- a/docs/api/qiskit/qasm3.mdx +++ b/docs/api/qiskit/qasm3.mdx @@ -26,7 +26,7 @@ The high-level functions are simply [`dump()`](#qiskit.qasm3.dump "qiskit.qasm3. ### dump - + Serialize a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") object as an OpenQASM 3 stream to file-like object. **Parameters** @@ -38,7 +38,7 @@ The high-level functions are simply [`dump()`](#qiskit.qasm3.dump "qiskit.qasm3. ### dumps - + Serialize a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") object in an OpenQASM 3 string. **Parameters** @@ -59,7 +59,7 @@ Both of these exporter functions are single-use wrappers around the main [`Expor ### Exporter - + QASM3 exporter main class. **Parameters** @@ -92,13 +92,13 @@ Both of these exporter functions are single-use wrappers around the main [`Expor #### dump - + Convert the circuit to OpenQASM 3, dumping the result to a file or text stream. #### dumps - + Convert the circuit to OpenQASM 3, returning the result as a string. @@ -107,7 +107,7 @@ All of these interfaces will raise [`QASM3ExporterError`](#qiskit.qasm3.QASM3Exp ### QASM3ExporterError - + An error raised during running the OpenQASM 3 exporter. Set the error message. @@ -119,7 +119,7 @@ The OpenQASM 3 language is still evolving as hardware capabilities improve, so t #### ExperimentalFeatures - + 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. @@ -213,7 +213,7 @@ Currently only two high-level functions are offered, as Qiskit support for impor ### load - + Load an OpenQASM 3 program from the file `filename`. **Parameters** @@ -235,7 +235,7 @@ Currently only two high-level functions are offered, as Qiskit support for impor ### loads - + Load an OpenQASM 3 program from the given string. **Parameters** @@ -259,7 +259,7 @@ Both of these two functions raise [`QASM3ImporterError`](#qiskit.qasm3.QASM3Impo ### QASM3ImporterError - + An error raised during the OpenQASM 3 importer. Set the error message. @@ -326,7 +326,7 @@ You can use the experimental interface immediately, with similar functions to th #### load\_experimental - + Load an OpenQASM 3 program from a source file into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). @@ -354,7 +354,7 @@ You can use the experimental interface immediately, with similar functions to th #### loads\_experimental - + Load an OpenQASM 3 program from a string into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). diff --git a/docs/api/qiskit/qiskit.assembler.RunConfig.mdx b/docs/api/qiskit/qiskit.assembler.RunConfig.mdx index 80be62fb55d..b7412d055b4 100644 --- a/docs/api/qiskit/qiskit.assembler.RunConfig.mdx +++ b/docs/api/qiskit/qiskit.assembler.RunConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.assembler.RunConfig # RunConfig - + Bases: [`SimpleNamespace`](https://docs.python.org/3/library/types.html#types.SimpleNamespace "(in Python v3.12)") Class for Run Configuration. @@ -67,7 +67,7 @@ python_api_name: qiskit.assembler.RunConfig ### from\_dict - + Create a new RunConfig object from a dictionary. **Parameters** @@ -85,7 +85,7 @@ python_api_name: qiskit.assembler.RunConfig ### to\_dict - + Return a dictionary format representation of the RunConfig **Returns** diff --git a/docs/api/qiskit/qiskit.circuit.AnnotatedOperation.mdx b/docs/api/qiskit/qiskit.circuit.AnnotatedOperation.mdx index 1222acdd120..7244e0fda91 100644 --- a/docs/api/qiskit/qiskit.circuit.AnnotatedOperation.mdx +++ b/docs/api/qiskit/qiskit.circuit.AnnotatedOperation.mdx @@ -8,14 +8,14 @@ python_api_name: qiskit.circuit.AnnotatedOperation # AnnotatedOperation - + 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” allows to add a list of modifiers to the “base” operation. For now, the only supported modifiers are of types [`InverseModifier`](circuit#qiskit.circuit.InverseModifier "qiskit.circuit.InverseModifier"), [`ControlModifier`](circuit#qiskit.circuit.ControlModifier "qiskit.circuit.ControlModifier") and [`PowerModifier`](circuit#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. @@ -57,11 +57,23 @@ python_api_name: qiskit.circuit.AnnotatedOperation Number of qubits. + ### base\_op + + + The base operation that the modifiers in this annotated operation applies to. + + + ### modifiers + + + Ordered sequence of the modifiers to apply to [`base_op`](#qiskit.circuit.AnnotatedOperation.base_op "qiskit.circuit.AnnotatedOperation.base_op"). The modifiers are applied in order from lowest index to highest index. + + ## Methods ### control - + Return the controlled version of itself. Implemented as an annotated operation, see [`AnnotatedOperation`](#qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). @@ -84,7 +96,7 @@ python_api_name: qiskit.circuit.AnnotatedOperation ### copy - + Return a copy of the [`AnnotatedOperation`](#qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). **Return type** @@ -94,7 +106,7 @@ python_api_name: qiskit.circuit.AnnotatedOperation ### inverse - + Return the inverse version of itself. Implemented as an annotated operation, see [`AnnotatedOperation`](#qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). @@ -108,9 +120,26 @@ python_api_name: qiskit.circuit.AnnotatedOperation Inverse version of the given operation. + ### power + + + Raise this gate to the power of `exponent`. + + Implemented as an annotated operation, see [`AnnotatedOperation`](#qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – ignored (used for consistency with other power methods) + + **Returns** + + An operation implementing `gate^exponent` + + ### to\_matrix - + Return a matrix representation (allowing to construct Operator). diff --git a/docs/api/qiskit/qiskit.circuit.BreakLoopOp.mdx b/docs/api/qiskit/qiskit.circuit.BreakLoopOp.mdx index b2082657e18..941748847f5 100644 --- a/docs/api/qiskit/qiskit.circuit.BreakLoopOp.mdx +++ b/docs/api/qiskit/qiskit.circuit.BreakLoopOp.mdx @@ -8,41 +8,16 @@ python_api_name: qiskit.circuit.BreakLoopOp # BreakLoopOp - + 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. + A circuit operation which, when encountered, jumps to the end of the nearest enclosing loop. Can only be used inside loops. **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. + * **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of qubits this affects. + * **num\_clbits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of qubits this affects. + * **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – an optional string label for the instruction. ## Attributes @@ -132,7 +107,7 @@ python_api_name: qiskit.circuit.BreakLoopOp ### params - return instruction params. + The parameters of this [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"). Ideally these will be gate angles. ### unit @@ -145,19 +120,19 @@ python_api_name: qiskit.circuit.BreakLoopOp ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -176,7 +151,7 @@ python_api_name: qiskit.circuit.BreakLoopOp ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -186,7 +161,7 @@ python_api_name: qiskit.circuit.BreakLoopOp ### copy - + Copy of the instruction. **Parameters** @@ -204,7 +179,7 @@ python_api_name: qiskit.circuit.BreakLoopOp ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -228,14 +203,16 @@ python_api_name: qiskit.circuit.BreakLoopOp ### is\_parameterized - - Return True .IFF. instruction is parameterized else False + + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### repeat - - Creates an instruction with gate repeated n amount of times. + + Creates an instruction with `self` repeated :math\`n\` times. + + If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. **Parameters** @@ -256,7 +233,7 @@ python_api_name: qiskit.circuit.BreakLoopOp ### 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. @@ -274,7 +251,7 @@ python_api_name: qiskit.circuit.BreakLoopOp ### soft\_compare - + 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** @@ -292,7 +269,7 @@ python_api_name: qiskit.circuit.BreakLoopOp ### 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. @@ -300,7 +277,7 @@ python_api_name: qiskit.circuit.BreakLoopOp ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/qiskit.circuit.ContinueLoopOp.mdx b/docs/api/qiskit/qiskit.circuit.ContinueLoopOp.mdx index 546c8a18304..d0478af16d8 100644 --- a/docs/api/qiskit/qiskit.circuit.ContinueLoopOp.mdx +++ b/docs/api/qiskit/qiskit.circuit.ContinueLoopOp.mdx @@ -8,45 +8,16 @@ python_api_name: qiskit.circuit.ContinueLoopOp # ContinueLoopOp - + 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. + A circuit operation which, when encountered, moves to the next iteration of the nearest enclosing loop. Can only be used inside loops. **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. + * **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of qubits this affects. + * **num\_clbits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of qubits this affects. + * **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – an optional string label for the instruction. ## Attributes @@ -136,7 +107,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### params - return instruction params. + The parameters of this [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"). Ideally these will be gate angles. ### unit @@ -149,19 +120,19 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -180,7 +151,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -190,7 +161,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### copy - + Copy of the instruction. **Parameters** @@ -208,7 +179,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -232,14 +203,16 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### is\_parameterized - - Return True .IFF. instruction is parameterized else False + + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### repeat - - Creates an instruction with gate repeated n amount of times. + + Creates an instruction with `self` repeated :math\`n\` times. + + If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. **Parameters** @@ -260,7 +233,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### 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. @@ -278,7 +251,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### soft\_compare - + 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** @@ -296,7 +269,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### 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. @@ -304,7 +277,7 @@ python_api_name: qiskit.circuit.ContinueLoopOp ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/qiskit.circuit.ControlFlowOp.mdx b/docs/api/qiskit/qiskit.circuit.ControlFlowOp.mdx index 26fba208aac..f088627569d 100644 --- a/docs/api/qiskit/qiskit.circuit.ControlFlowOp.mdx +++ b/docs/api/qiskit/qiskit.circuit.ControlFlowOp.mdx @@ -8,11 +8,13 @@ python_api_name: qiskit.circuit.ControlFlowOp # ControlFlowOp - + 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. + All subclasses of [`ControlFlowOp`](#qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") have an internal attribute, [`blocks`](#qiskit.circuit.ControlFlowOp.blocks "qiskit.circuit.ControlFlowOp.blocks"), which exposes the inner subcircuits used in the different blocks of the control flow. + Create a new instruction. **Parameters** @@ -56,7 +58,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### 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. + Tuple of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")s which may be executed as part of the execution of this [`ControlFlowOp`](#qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp"). ### condition @@ -124,7 +126,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### params - return instruction params. + The parameters of this [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"). Ideally these will be gate angles. ### unit @@ -137,19 +139,19 @@ python_api_name: qiskit.circuit.ControlFlowOp ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -168,7 +170,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -178,7 +180,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### copy - + Copy of the instruction. **Parameters** @@ -196,7 +198,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -220,14 +222,26 @@ python_api_name: qiskit.circuit.ControlFlowOp ### is\_parameterized - - Return True .IFF. instruction is parameterized else False + + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). + + + ### iter\_captured\_vars + + + Get an iterator over the unique captured variables in all blocks of this construct. + + **Return type** + + [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[expr.Var](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")] ### repeat - - Creates an instruction with gate repeated n amount of times. + + Creates an instruction with `self` repeated :math\`n\` times. + + If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. **Parameters** @@ -248,12 +262,33 @@ python_api_name: qiskit.circuit.ControlFlowOp ### replace\_blocks - - Replace blocks and return new instruction. :param blocks: Tuple of QuantumCircuits to replace in instruction. + + Return a new version of this control-flow operations with the [`blocks`](#qiskit.circuit.ControlFlowOp.blocks "qiskit.circuit.ControlFlowOp.blocks") mapped to the given new ones. + + Typically this is used in a workflow such as: + + ```python + existing_op = ... + + def map_block(block: QuantumCircuit) -> QuantumCircuit: + new_block = block.copy_empty_like() + # ... do something to `new_block` ... + return new_block + + new_op = existing_op.replace_blocks( + map_block(block) for block in existing_op.blocks + ) + ``` + + It is the caller’s responsibility to ensure that the mapped blocks are defined over a unified set of circuit resources, much like constructing a [`ControlFlowOp`](#qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") using its default constructor. + + **Parameters** + + **blocks** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – the new subcircuit blocks to use. **Returns** - New ControlFlowOp with replaced blocks. + New [`ControlFlowOp`](#qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") with replaced blocks. **Return type** @@ -262,7 +297,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### 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. @@ -280,7 +315,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### soft\_compare - + 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** @@ -298,7 +333,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### 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. @@ -306,7 +341,7 @@ python_api_name: qiskit.circuit.ControlFlowOp ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/qiskit.circuit.ControlledGate.mdx b/docs/api/qiskit/qiskit.circuit.ControlledGate.mdx index 1d8d376a480..5229326d0b0 100644 --- a/docs/api/qiskit/qiskit.circuit.ControlledGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.ControlledGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.ControlledGate # ControlledGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Controlled unitary gate. @@ -116,7 +116,7 @@ python_api_name: qiskit.circuit.ControlledGate ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.ControlledGate.ctrl_state "qiskit.circuit.ControlledGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -203,19 +203,19 @@ python_api_name: qiskit.circuit.ControlledGate ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + 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: @@ -268,7 +268,7 @@ python_api_name: qiskit.circuit.ControlledGate ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -278,7 +278,7 @@ python_api_name: qiskit.circuit.ControlledGate ### control - + Return the controlled version of itself. Implemented either as a controlled gate (ref. [`ControlledGate`](#qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). @@ -301,7 +301,7 @@ python_api_name: qiskit.circuit.ControlledGate ### copy - + Copy of the instruction. **Parameters** @@ -319,7 +319,7 @@ python_api_name: qiskit.circuit.ControlledGate ### inverse - + Invert this gate by calling inverse on the base gate. **Return type** @@ -329,36 +329,37 @@ python_api_name: qiskit.circuit.ControlledGate ### is\_parameterized - - Return True .IFF. instruction is parameterized else False + + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### power - - Creates a unitary gate as gate^exponent. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. **Parameters** - **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Gate^exponent + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. **Returns** - To which to\_matrix is self.to\_matrix^exponent. - - **Return type** - - .library.UnitaryGate + An operation implementing `gate^exponent` **Raises** - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If Gate is not unitary + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary ### repeat - - Creates an instruction with gate repeated n amount of times. + + Creates an instruction with `self` repeated :math\`n\` times. + + If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. **Parameters** @@ -379,7 +380,7 @@ python_api_name: qiskit.circuit.ControlledGate ### 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. @@ -397,7 +398,7 @@ python_api_name: qiskit.circuit.ControlledGate ### soft\_compare - + 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** @@ -415,7 +416,7 @@ python_api_name: qiskit.circuit.ControlledGate ### to\_matrix - + Return a Numpy.array for the gate unitary matrix. **Returns** @@ -433,7 +434,7 @@ python_api_name: qiskit.circuit.ControlledGate ### 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. @@ -441,7 +442,7 @@ python_api_name: qiskit.circuit.ControlledGate ### validate\_parameter - + Gate parameters should be int, float, or ParameterExpression diff --git a/docs/api/qiskit/qiskit.circuit.EquivalenceLibrary.mdx b/docs/api/qiskit/qiskit.circuit.EquivalenceLibrary.mdx index b9fb4970ae7..a9feae0eb98 100644 --- a/docs/api/qiskit/qiskit.circuit.EquivalenceLibrary.mdx +++ b/docs/api/qiskit/qiskit.circuit.EquivalenceLibrary.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary # EquivalenceLibrary - + 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. @@ -41,7 +41,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary ### add\_equivalence - + 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. @@ -54,7 +54,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary ### draw - + Draws the equivalence relations available in the library. **Parameters** @@ -78,7 +78,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary ### get\_entry - + 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. @@ -102,7 +102,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary ### has\_entry - + Check if a library contains any decompositions for gate. **Parameters** @@ -122,7 +122,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary ### keys - + Return list of keys to key to node index map. **Returns** @@ -136,7 +136,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary ### node\_index - + Return node index for a given key. **Parameters** @@ -154,7 +154,7 @@ python_api_name: qiskit.circuit.EquivalenceLibrary ### set\_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. diff --git a/docs/api/qiskit/qiskit.circuit.ForLoopOp.mdx b/docs/api/qiskit/qiskit.circuit.ForLoopOp.mdx index b868ff7214c..d4452a25b0b 100644 --- a/docs/api/qiskit/qiskit.circuit.ForLoopOp.mdx +++ b/docs/api/qiskit/qiskit.circuit.ForLoopOp.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.ForLoopOp # ForLoopOp - + 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`. @@ -20,37 +20,6 @@ python_api_name: qiskit.circuit.ForLoopOp * **body** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The loop body to be repeatedly executed. * **label** (*Optional\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – 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 @@ -154,19 +123,19 @@ python_api_name: qiskit.circuit.ForLoopOp ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -185,7 +154,7 @@ python_api_name: qiskit.circuit.ForLoopOp ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -195,7 +164,7 @@ python_api_name: qiskit.circuit.ForLoopOp ### copy - + Copy of the instruction. **Parameters** @@ -213,7 +182,7 @@ python_api_name: qiskit.circuit.ForLoopOp ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -237,14 +206,26 @@ python_api_name: qiskit.circuit.ForLoopOp ### is\_parameterized - - Return True .IFF. instruction is parameterized else False + + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). + + + ### iter\_captured\_vars + + + Get an iterator over the unique captured variables in all blocks of this construct. + + **Return type** + + [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[expr.Var](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")] ### repeat - - Creates an instruction with gate repeated n amount of times. + + Creates an instruction with `self` repeated :math\`n\` times. + + If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. **Parameters** @@ -265,17 +246,38 @@ python_api_name: qiskit.circuit.ForLoopOp ### replace\_blocks - - Replace blocks and return new instruction. :param blocks: Tuple of QuantumCircuits to replace in instruction. + + Return a new version of this control-flow operations with the [`blocks`](#qiskit.circuit.ForLoopOp.blocks "qiskit.circuit.ForLoopOp.blocks") mapped to the given new ones. + + Typically this is used in a workflow such as: + + ```python + existing_op = ... + + def map_block(block: QuantumCircuit) -> QuantumCircuit: + new_block = block.copy_empty_like() + # ... do something to `new_block` ... + return new_block + + new_op = existing_op.replace_blocks( + map_block(block) for block in existing_op.blocks + ) + ``` + + It is the caller’s responsibility to ensure that the mapped blocks are defined over a unified set of circuit resources, much like constructing a [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") using its default constructor. + + **Parameters** + + **blocks** – the new subcircuit blocks to use. **Returns** - New ControlFlowOp with replaced blocks. + New [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") with replaced blocks. ### 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. @@ -293,7 +295,7 @@ python_api_name: qiskit.circuit.ForLoopOp ### soft\_compare - + 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** @@ -311,7 +313,7 @@ python_api_name: qiskit.circuit.ForLoopOp ### 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. @@ -319,7 +321,7 @@ python_api_name: qiskit.circuit.ForLoopOp ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/qiskit.circuit.Gate.mdx b/docs/api/qiskit/qiskit.circuit.Gate.mdx index e1e1cb84808..e2e862bc4f9 100644 --- a/docs/api/qiskit/qiskit.circuit.Gate.mdx +++ b/docs/api/qiskit/qiskit.circuit.Gate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.Gate # Gate - + Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") Unitary gate. @@ -110,7 +110,7 @@ python_api_name: qiskit.circuit.Gate ### params - return instruction params. + The parameters of this [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"). Ideally these will be gate angles. ### unit @@ -123,19 +123,19 @@ python_api_name: qiskit.circuit.Gate ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + 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: @@ -188,7 +188,7 @@ python_api_name: qiskit.circuit.Gate ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -198,7 +198,7 @@ python_api_name: qiskit.circuit.Gate ### control - + Return the controlled version of itself. Implemented either as a controlled gate (ref. [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). @@ -221,7 +221,7 @@ python_api_name: qiskit.circuit.Gate ### copy - + Copy of the instruction. **Parameters** @@ -239,7 +239,7 @@ python_api_name: qiskit.circuit.Gate ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -263,36 +263,37 @@ python_api_name: qiskit.circuit.Gate ### is\_parameterized - - Return True .IFF. instruction is parameterized else False + + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### power - - Creates a unitary gate as gate^exponent. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. **Parameters** - **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Gate^exponent + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. **Returns** - To which to\_matrix is self.to\_matrix^exponent. - - **Return type** - - .library.UnitaryGate + An operation implementing `gate^exponent` **Raises** - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If Gate is not unitary + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary ### repeat - - Creates an instruction with gate repeated n amount of times. + + Creates an instruction with `self` repeated :math\`n\` times. + + If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. **Parameters** @@ -313,7 +314,7 @@ python_api_name: qiskit.circuit.Gate ### 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. @@ -331,7 +332,7 @@ python_api_name: qiskit.circuit.Gate ### soft\_compare - + 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** @@ -349,7 +350,7 @@ python_api_name: qiskit.circuit.Gate ### to\_matrix - + Return a Numpy.array for the gate unitary matrix. **Returns** @@ -367,7 +368,7 @@ python_api_name: qiskit.circuit.Gate ### 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. @@ -375,7 +376,7 @@ python_api_name: qiskit.circuit.Gate ### validate\_parameter - + Gate parameters should be int, float, or ParameterExpression diff --git a/docs/api/qiskit/qiskit.circuit.IfElseOp.mdx b/docs/api/qiskit/qiskit.circuit.IfElseOp.mdx index dce3b36e293..024a87d23fb 100644 --- a/docs/api/qiskit/qiskit.circuit.IfElseOp.mdx +++ b/docs/api/qiskit/qiskit.circuit.IfElseOp.mdx @@ -8,52 +8,21 @@ python_api_name: qiskit.circuit.IfElseOp # IfElseOp - + 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. + * **condition** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*ClassicalRegister*](circuit#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*](circuit#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 in real time during circuit execution 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. ## Attributes @@ -158,19 +127,19 @@ python_api_name: qiskit.circuit.IfElseOp ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -189,7 +158,7 @@ python_api_name: qiskit.circuit.IfElseOp ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -199,7 +168,7 @@ python_api_name: qiskit.circuit.IfElseOp ### copy - + Copy of the instruction. **Parameters** @@ -217,7 +186,7 @@ python_api_name: qiskit.circuit.IfElseOp ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -241,14 +210,26 @@ python_api_name: qiskit.circuit.IfElseOp ### is\_parameterized - - Return True .IFF. instruction is parameterized else False + + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). + + + ### iter\_captured\_vars + + + Get an iterator over the unique captured variables in all blocks of this construct. + + **Return type** + + [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[expr.Var](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")] ### repeat - - Creates an instruction with gate repeated n amount of times. + + Creates an instruction with `self` repeated :math\`n\` times. + + If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. **Parameters** @@ -269,7 +250,7 @@ python_api_name: qiskit.circuit.IfElseOp ### replace\_blocks - + Replace blocks and return new instruction. **Parameters** @@ -287,7 +268,7 @@ python_api_name: qiskit.circuit.IfElseOp ### 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. @@ -305,7 +286,7 @@ python_api_name: qiskit.circuit.IfElseOp ### soft\_compare - + 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** @@ -323,7 +304,7 @@ python_api_name: qiskit.circuit.IfElseOp ### 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. @@ -331,7 +312,7 @@ python_api_name: qiskit.circuit.IfElseOp ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/qiskit.circuit.Instruction.mdx b/docs/api/qiskit/qiskit.circuit.Instruction.mdx index 15d4fd6d403..51caea613a1 100644 --- a/docs/api/qiskit/qiskit.circuit.Instruction.mdx +++ b/docs/api/qiskit/qiskit.circuit.Instruction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.Instruction # Instruction - + Bases: [`Operation`](qiskit.circuit.Operation "qiskit.circuit.operation.Operation") Generic quantum instruction. @@ -118,7 +118,7 @@ python_api_name: qiskit.circuit.Instruction ### params - return instruction params. + The parameters of this [`Instruction`](#qiskit.circuit.Instruction "qiskit.circuit.Instruction"). Ideally these will be gate angles. ### unit @@ -131,19 +131,19 @@ python_api_name: qiskit.circuit.Instruction ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -162,7 +162,7 @@ python_api_name: qiskit.circuit.Instruction ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -172,7 +172,7 @@ python_api_name: qiskit.circuit.Instruction ### copy - + Copy of the instruction. **Parameters** @@ -190,7 +190,7 @@ python_api_name: qiskit.circuit.Instruction ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -214,14 +214,16 @@ python_api_name: qiskit.circuit.Instruction ### is\_parameterized - - Return True .IFF. instruction is parameterized else False + + Return whether the [`Instruction`](#qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### repeat - - Creates an instruction with gate repeated n amount of times. + + Creates an instruction with `self` repeated :math\`n\` times. + + If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. **Parameters** @@ -242,7 +244,7 @@ python_api_name: qiskit.circuit.Instruction ### 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. @@ -260,7 +262,7 @@ python_api_name: qiskit.circuit.Instruction ### soft\_compare - + 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** @@ -278,7 +280,7 @@ python_api_name: qiskit.circuit.Instruction ### 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. @@ -286,7 +288,7 @@ python_api_name: qiskit.circuit.Instruction ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/qiskit.circuit.InstructionSet.mdx b/docs/api/qiskit/qiskit.circuit.InstructionSet.mdx index ad502ea7dbe..c227279a4aa 100644 --- a/docs/api/qiskit/qiskit.circuit.InstructionSet.mdx +++ b/docs/api/qiskit/qiskit.circuit.InstructionSet.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.InstructionSet # InstructionSet - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Instruction collection, and their contexts. @@ -19,9 +19,9 @@ python_api_name: qiskit.circuit.InstructionSet **Parameters** - **resource\_requester** (*Callable\[...,* [*ClassicalRegister*](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") *|*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*] | None*) – + **resource\_requester** (*Callable\[...,* [*ClassicalRegister*](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") *|*[*Clbit*](circuit#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. + 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`](circuit#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`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") and [`ClassicalRegister`](circuit#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. @@ -51,14 +51,18 @@ python_api_name: qiskit.circuit.InstructionSet ### add - + Add an instruction and its context (where it is attached). ### c\_if - - 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`. + + Set a classical equality condition on all the instructions in this set between the [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") or [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") `classical` and value `val`. + + + You should prefer to use the [`QuantumCircuit.if_test()`](qiskit.circuit.QuantumCircuit#if_test "qiskit.circuit.QuantumCircuit.if_test") builder interface, rather than using this method. + 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. @@ -66,7 +70,7 @@ python_api_name: qiskit.circuit.InstructionSet **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. + * **classical** ([*Clbit*](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") *|*[*ClassicalRegister*](circuit#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`](circuit#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** @@ -80,34 +84,16 @@ python_api_name: qiskit.circuit.InstructionSet **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/qiskit-circuit-InstructionSet-1.png) ### inverse - + Invert all instructions. + + + It is preferable to take the inverse *before* appending the gate(s) to the circuit. + diff --git a/docs/api/qiskit/qiskit.circuit.Operation.mdx b/docs/api/qiskit/qiskit.circuit.Operation.mdx index 2bc23e34665..dd5e797f9ff 100644 --- a/docs/api/qiskit/qiskit.circuit.Operation.mdx +++ b/docs/api/qiskit/qiskit.circuit.Operation.mdx @@ -8,14 +8,20 @@ python_api_name: qiskit.circuit.Operation # Operation - + 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. + Quantum operation interface. + + The minimal interface that any object must fulfil in order to be added to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + + Concrete instances of this interface include [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"), [`Reset`](circuit#qiskit.circuit.Reset "qiskit.circuit.Reset"), [`Barrier`](circuit#qiskit.circuit.Barrier "qiskit.circuit.Barrier"), [`Measure`](circuit#qiskit.circuit.Measure "qiskit.circuit.Measure"), and operators such as [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford"). + + The main purpose is to add allow abstract mathematical objects to be added directly onto abstract circuits, and for the exact syntheses of these to be determined later, during compilation. **Example** - Add a Clifford and a Toffoli gate to a QuantumCircuit. + Add a Clifford and a Toffoli gate to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). ```python from qiskit import QuantumCircuit diff --git a/docs/api/qiskit/qiskit.circuit.Parameter.mdx b/docs/api/qiskit/qiskit.circuit.Parameter.mdx index 29b14974831..e23cdfd633c 100644 --- a/docs/api/qiskit/qiskit.circuit.Parameter.mdx +++ b/docs/api/qiskit/qiskit.circuit.Parameter.mdx @@ -8,12 +8,14 @@ python_api_name: qiskit.circuit.Parameter # Parameter - + Bases: [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") - Parameter Class for variable parameters. + A compile-time symbolic parameter. - A parameter is a variable value that is not required to be fixed at circuit definition. + The value of a [`Parameter`](#qiskit.circuit.Parameter "qiskit.circuit.Parameter") must be entirely determined before a circuit begins execution. Typically this will mean that you should supply values for all [`Parameter`](#qiskit.circuit.Parameter "qiskit.circuit.Parameter")s in a circuit using [`QuantumCircuit.assign_parameters()`](qiskit.circuit.QuantumCircuit#assign_parameters "qiskit.circuit.QuantumCircuit.assign_parameters"), though certain hardware vendors may allow you to give them a circuit in terms of these parameters, provided you also pass the values separately. + + This is the atom of [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression"), and is itself an expression. The numeric value of a parameter need not be fixed while the circuit is being defined. **Examples** @@ -40,11 +42,9 @@ python_api_name: qiskit.circuit.Parameter ![../\_images/qiskit-circuit-Parameter-1\_01.png](/images/api/qiskit/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. “ϕ”. + * **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 @@ -73,31 +73,31 @@ python_api_name: qiskit.circuit.Parameter ### abs - + Absolute of a ParameterExpression ### arccos - + Arccos of a ParameterExpression ### arcsin - + Arcsin of a ParameterExpression ### arctan - + Arctan of a ParameterExpression ### assign - + Assign one parameter to a value, which can either be numeric or another parameter expression. **Parameters** @@ -112,7 +112,7 @@ python_api_name: qiskit.circuit.Parameter ### bind - + Binds the provided set of parameters to their corresponding values. **Parameters** @@ -141,7 +141,7 @@ python_api_name: qiskit.circuit.Parameter ### conjugate - + Return the conjugate. **Return type** @@ -151,19 +151,19 @@ python_api_name: qiskit.circuit.Parameter ### cos - + Cosine of a ParameterExpression ### exp - + Exponential of a ParameterExpression ### gradient - + Get the derivative of a parameter expression w\.r.t. a specified parameter expression. **Parameters** @@ -181,19 +181,19 @@ python_api_name: qiskit.circuit.Parameter ### is\_real - + Return whether the expression is real ### log - + Logarithm of a ParameterExpression ### numeric - + Return a Python number representing this object, using the most restrictive of [`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)") and [`complex`](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") that is valid for this object. In general, an [`int`](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") is only returned if the expression only involved symbolic integers. If floating-point values were used during the evaluation, the return value will be a [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") regardless of whether the represented value is an integer. This is because floating-point values “infect” symbolic computations by their inexact nature, and symbolic libraries will use inexact floating-point semantics not exact real-number semantics when they are involved. If you want to assert that all floating-point calculations *were* carried out at infinite precision (i.e. [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") could represent every intermediate value exactly), you can use [`float.is_integer()`](https://docs.python.org/3/library/stdtypes.html#float.is_integer "(in Python v3.12)") to check if the return float represents an integer and cast it using [`int`](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") if so. This would be an unusual pattern; typically one requires this by only ever using explicitly [`Rational`](https://docs.python.org/3/library/numbers.html#numbers.Rational "(in Python v3.12)") objects while working with symbolic expressions. @@ -215,25 +215,25 @@ python_api_name: qiskit.circuit.Parameter ### sign - + Sign of a ParameterExpression ### sin - + Sine of a ParameterExpression ### subs - + Substitute self with the corresponding parameter in `parameter_map`. ### 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. @@ -245,7 +245,7 @@ python_api_name: qiskit.circuit.Parameter ### tan - + Tangent of a ParameterExpression diff --git a/docs/api/qiskit/qiskit.circuit.ParameterExpression.mdx b/docs/api/qiskit/qiskit.circuit.ParameterExpression.mdx index 7b1534a6e4e..1395c9d5eec 100644 --- a/docs/api/qiskit/qiskit.circuit.ParameterExpression.mdx +++ b/docs/api/qiskit/qiskit.circuit.ParameterExpression.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.ParameterExpression # ParameterExpression - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") ParameterExpression class to enable creating expressions of Parameters. @@ -34,31 +34,31 @@ python_api_name: qiskit.circuit.ParameterExpression ### abs - + Absolute of a ParameterExpression ### arccos - + Arccos of a ParameterExpression ### arcsin - + Arcsin of a ParameterExpression ### arctan - + Arctan of a ParameterExpression ### assign - + Assign one parameter to a value, which can either be numeric or another parameter expression. **Parameters** @@ -77,7 +77,7 @@ python_api_name: qiskit.circuit.ParameterExpression ### bind - + Binds the provided set of parameters to their corresponding values. **Parameters** @@ -106,7 +106,7 @@ python_api_name: qiskit.circuit.ParameterExpression ### conjugate - + Return the conjugate. **Return type** @@ -116,19 +116,19 @@ python_api_name: qiskit.circuit.ParameterExpression ### cos - + Cosine of a ParameterExpression ### exp - + Exponential of a ParameterExpression ### gradient - + Get the derivative of a parameter expression w\.r.t. a specified parameter expression. **Parameters** @@ -146,19 +146,19 @@ python_api_name: qiskit.circuit.ParameterExpression ### is\_real - + Return whether the expression is real ### log - + Logarithm of a ParameterExpression ### numeric - + Return a Python number representing this object, using the most restrictive of [`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)") and [`complex`](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") that is valid for this object. In general, an [`int`](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") is only returned if the expression only involved symbolic integers. If floating-point values were used during the evaluation, the return value will be a [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") regardless of whether the represented value is an integer. This is because floating-point values “infect” symbolic computations by their inexact nature, and symbolic libraries will use inexact floating-point semantics not exact real-number semantics when they are involved. If you want to assert that all floating-point calculations *were* carried out at infinite precision (i.e. [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") could represent every intermediate value exactly), you can use [`float.is_integer()`](https://docs.python.org/3/library/stdtypes.html#float.is_integer "(in Python v3.12)") to check if the return float represents an integer and cast it using [`int`](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") if so. This would be an unusual pattern; typically one requires this by only ever using explicitly [`Rational`](https://docs.python.org/3/library/numbers.html#numbers.Rational "(in Python v3.12)") objects while working with symbolic expressions. @@ -180,19 +180,19 @@ python_api_name: qiskit.circuit.ParameterExpression ### sign - + Sign of a ParameterExpression ### sin - + Sine of a ParameterExpression ### subs - + Returns a new Expression with replacement Parameters. **Parameters** @@ -217,7 +217,7 @@ python_api_name: qiskit.circuit.ParameterExpression ### 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. @@ -229,7 +229,7 @@ python_api_name: qiskit.circuit.ParameterExpression ### tan - + Tangent of a ParameterExpression diff --git a/docs/api/qiskit/qiskit.circuit.ParameterVector.mdx b/docs/api/qiskit/qiskit.circuit.ParameterVector.mdx index db52e422500..40a1916f100 100644 --- a/docs/api/qiskit/qiskit.circuit.ParameterVector.mdx +++ b/docs/api/qiskit/qiskit.circuit.ParameterVector.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.ParameterVector # ParameterVector - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") ParameterVector class to quickly generate lists of parameters. @@ -31,13 +31,13 @@ python_api_name: qiskit.circuit.ParameterVector ### index - + Returns first index of value. ### resize - + 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/qiskit.circuit.QuantumCircuit.mdx b/docs/api/qiskit/qiskit.circuit.QuantumCircuit.mdx index d462aa8ae5a..70c9b71a8fa 100644 --- a/docs/api/qiskit/qiskit.circuit.QuantumCircuit.mdx +++ b/docs/api/qiskit/qiskit.circuit.QuantumCircuit.mdx @@ -6,124 +6,60 @@ python_api_type: class python_api_name: qiskit.circuit.QuantumCircuit --- -# QuantumCircuit - - - 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/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/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. - + + + + +# [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") class + + + Core Qiskit representation of a quantum circuit. + + + For more details setting the [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") in context of all of the data structures that go with it, how it fits into the rest of the [`qiskit`](index#module-qiskit "qiskit") package, and the different regimes of quantum-circuit descriptions in Qiskit, see the module-level documentation of [`qiskit.circuit`](circuit#module-qiskit.circuit "qiskit.circuit"). + + + ## Circuit attributes + + [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") has a small number of public attributes, which are mostly older functionality. Most of its functionality is accessed through methods. + + A small handful of the attributes are intentionally mutable, the rest are data attributes that should be considered immutable. + + | Mutable attribute | Summary | + | ---------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------- | + | [`global_phase`](#qiskit.circuit.QuantumCircuit.global_phase "qiskit.circuit.QuantumCircuit.global_phase") | The global phase of the circuit, measured in radians. | + | [`metadata`](#qiskit.circuit.QuantumCircuit.metadata "qiskit.circuit.QuantumCircuit.metadata") | Arbitrary user mapping, which Qiskit will preserve through the transpiler, but otherwise completely ignore. | + | [`name`](#qiskit.circuit.QuantumCircuit.name "qiskit.circuit.QuantumCircuit.name") | An optional string name for the circuit. | + + | Immutable data attribute | Summary | + | ------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------- | + | [`ancillas`](#qiskit.circuit.QuantumCircuit.ancillas "qiskit.circuit.QuantumCircuit.ancillas") | List of [`AncillaQubit`](circuit#qiskit.circuit.AncillaQubit "qiskit.circuit.AncillaQubit")s tracked by the circuit. | + | [`calibrations`](#qiskit.circuit.QuantumCircuit.calibrations "qiskit.circuit.QuantumCircuit.calibrations") | Custom user-supplied pulse calibrations for individual instructions. | + | [`cregs`](#qiskit.circuit.QuantumCircuit.cregs "qiskit.circuit.QuantumCircuit.cregs") | List of [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")s tracked by the circuit. | + | [`clbits`](#qiskit.circuit.QuantumCircuit.clbits "qiskit.circuit.QuantumCircuit.clbits") | List of [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit")s tracked by the circuit. | + | [`data`](#qiskit.circuit.QuantumCircuit.data "qiskit.circuit.QuantumCircuit.data") | List of individual [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s that make up the circuit. | + | [`duration`](#qiskit.circuit.QuantumCircuit.duration "qiskit.circuit.QuantumCircuit.duration") | Total duration of the circuit, added by scheduling transpiler passes. | + | [`layout`](#qiskit.circuit.QuantumCircuit.layout "qiskit.circuit.QuantumCircuit.layout") | Hardware layout and routing information added by the transpiler. | + | [`num_ancillas`](#qiskit.circuit.QuantumCircuit.num_ancillas "qiskit.circuit.QuantumCircuit.num_ancillas") | The number of ancilla qubits in the circuit. | + | [`num_clbits`](#qiskit.circuit.QuantumCircuit.num_clbits "qiskit.circuit.QuantumCircuit.num_clbits") | The number of clbits in the circuit. | + | [`num_captured_vars`](#qiskit.circuit.QuantumCircuit.num_captured_vars "qiskit.circuit.QuantumCircuit.num_captured_vars") | Number of captured real-time classical variables. | + | [`num_declared_vars`](#qiskit.circuit.QuantumCircuit.num_declared_vars "qiskit.circuit.QuantumCircuit.num_declared_vars") | Number of locally declared real-time classical variables in the outer circuit scope. | + | [`num_input_vars`](#qiskit.circuit.QuantumCircuit.num_input_vars "qiskit.circuit.QuantumCircuit.num_input_vars") | Number of input real-time classical variables. | + | [`num_parameters`](#qiskit.circuit.QuantumCircuit.num_parameters "qiskit.circuit.QuantumCircuit.num_parameters") | Number of compile-time [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")s in the circuit. | + | [`num_qubits`](#qiskit.circuit.QuantumCircuit.num_qubits "qiskit.circuit.QuantumCircuit.num_qubits") | Number of qubits in the circuit. | + | [`num_vars`](#qiskit.circuit.QuantumCircuit.num_vars "qiskit.circuit.QuantumCircuit.num_vars") | Total number of real-time classical variables in the outer circuit scope. | + | [`op_start_times`](#qiskit.circuit.QuantumCircuit.op_start_times "qiskit.circuit.QuantumCircuit.op_start_times") | Start times of scheduled operations, added by scheduling transpiler passes. | + | [`parameters`](#qiskit.circuit.QuantumCircuit.parameters "qiskit.circuit.QuantumCircuit.parameters") | Ordered set-like view of the compile-time [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")s tracked by the circuit. | + | [`qregs`](#qiskit.circuit.QuantumCircuit.qregs "qiskit.circuit.QuantumCircuit.qregs") | List of [`QuantumRegister`](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister")s tracked by the circuit. | + | [`qubits`](#qiskit.circuit.QuantumCircuit.qubits "qiskit.circuit.QuantumCircuit.qubits") | List of [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")s tracked by the circuit. | + | [`unit`](#qiskit.circuit.QuantumCircuit.unit "qiskit.circuit.QuantumCircuit.unit") | The unit of the [`duration`](#qiskit.circuit.QuantumCircuit.duration "qiskit.circuit.QuantumCircuit.duration") field. | + + The core attribute is [`data`](#qiskit.circuit.QuantumCircuit.data "qiskit.circuit.QuantumCircuit.data"). This is a sequence-like object that exposes the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s contained in an ordered form. You generally should not mutate this object directly; [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") is only designed for append-only operations (which should use [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append")). Most operations that mutate circuits in place should be written as transpiler passes ([`qiskit.transpiler`](transpiler#module-qiskit.transpiler "qiskit.transpiler")). ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -134,74 +70,66 @@ python_api_name: qiskit.circuit.QuantumCircuit QuantumCircuitData + Alongside the [`data`](#qiskit.circuit.QuantumCircuit.data "qiskit.circuit.QuantumCircuit.data"), the [`global_phase`](#qiskit.circuit.QuantumCircuit.global_phase "qiskit.circuit.QuantumCircuit.global_phase") of a circuit can have some impact on its output, if the circuit is used to describe a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") that may be controlled. This is measured in radians and is directly settable. + ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. - ### instances - - - - ### layout - - - Return any associated layout information about the circuit + The [`name`](#qiskit.circuit.QuantumCircuit.name "qiskit.circuit.QuantumCircuit.name") of a circuit becomes the name of the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") or [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") resulting from [`to_instruction()`](#qiskit.circuit.QuantumCircuit.to_instruction "qiskit.circuit.QuantumCircuit.to_instruction") and [`to_gate()`](#qiskit.circuit.QuantumCircuit.to_gate "qiskit.circuit.QuantumCircuit.to_gate") calls, which can be handy for visualizations. - 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. + ### name - 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. + + A human-readable name for the circuit. + You can attach arbitrary [`metadata`](#qiskit.circuit.QuantumCircuit.metadata "qiskit.circuit.QuantumCircuit.metadata") to a circuit. No part of core Qiskit will inspect this or change its behavior based on metadata, but it will be faithfully passed through the transpiler, so you can tag your circuits yourself. When serializing a circuit with QPY (see [`qiskit.qpy`](qpy#module-qiskit.qpy "qiskit.qpy")), the metadata will be JSON-serialized and you may need to pass a custom serializer to handle non-JSON-compatible objects within it (see [`qpy.dump()`](qpy#qiskit.qpy.dump "qiskit.qpy.dump") for more detail). This field is ignored during export to OpenQASM 2 or 3. + ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. - ### num\_ancillas - - - Return the number of ancilla qubits. - + [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") exposes data attributes tracking its internal quantum and classical bits and registers. These appear as Python [`list`](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")s, but you should treat them as immutable; changing them will *at best* have no effect, and more likely will simply corrupt the internal data of the [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). - ### num\_clbits + ### qregs - - Return number of classical bits. + + A list of the [`QuantumRegister`](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister")s in this circuit. You should not mutate this. - ### num\_parameters + ### cregs - - The number of parameter objects in the circuit. + + A list of the [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")s in this circuit. You should not mutate this. - ### num\_qubits + ### qubits - - Return number of qubits. + + A list of [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")s in the order that they were added. You should not mutate this. - ### 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** + ### ancillas - 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"). + + A list of [`AncillaQubit`](circuit#qiskit.circuit.AncillaQubit "qiskit.circuit.AncillaQubit")s in the order that they were added. You should not mutate this. + - **Raises** + ### clbits - [**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + A list of [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit")s in the order that they were added. You should not mutate this. + The [compile-time parameters](circuit#circuit-compile-time-parameters) present in instructions on the circuit are available in [`parameters`](#qiskit.circuit.QuantumCircuit.parameters "qiskit.circuit.QuantumCircuit.parameters"). This has a canonical order (mostly lexical, except in the case of [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector")), which matches the order that parameters will be assigned when using the list forms of [`assign_parameters()`](#qiskit.circuit.QuantumCircuit.assign_parameters "qiskit.circuit.QuantumCircuit.assign_parameters"), but also supports [`set`](https://docs.python.org/3/library/stdtypes.html#set "(in Python v3.12)")-like constant-time membership testing. + ### parameters @@ -260,1188 +188,1353 @@ python_api_name: qiskit.circuit.QuantumCircuit The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. - ### prefix + The storage of any [manual pulse-level calibrations](#circuit-calibrations) for individual instructions on the circuit is in [`calibrations`](#qiskit.circuit.QuantumCircuit.calibrations "qiskit.circuit.QuantumCircuit.calibrations"). This presents as a [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)"), but should not be mutated directly; use the methods discussed in [Manual calibration of instructions](#circuit-calibrations). - + ### calibrations - ### qubits + + Return calibration dictionary. - - Returns a list of quantum bits in the order that the registers were added. + The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` - ## Methods - - ### add\_bits - - - Add Bits to the circuit. - - - ### add\_calibration - - - Register a low-level, custom pulse definition for the given gate. + If you have transpiled your circuit, so you have a physical circuit, you can inspect the [`layout`](#qiskit.circuit.QuantumCircuit.layout "qiskit.circuit.QuantumCircuit.layout") attribute for information stored by the transpiler about how the virtual qubits of the source circuit map to the hardware qubits of your physical circuit, both at the start and end of the circuit. - **Parameters** + ### layout - * **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. + + Return any associated layout information about the circuit - **Raises** + 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. - [**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. - + 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. + - ### add\_register + If your circuit was also *scheduled* as part of a transpilation, it will expose the individual timings of each instruction, along with the total [`duration`](#qiskit.circuit.QuantumCircuit.duration "qiskit.circuit.QuantumCircuit.duration") of the circuit. - - Add registers. - + ### duration - ### append + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.QuantumCircuit.unit "qiskit.circuit.QuantumCircuit.unit"). + - - Append one or more instructions to the end of the circuit, modifying the circuit in place. + ### unit - 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. + + The unit that [`duration`](#qiskit.circuit.QuantumCircuit.duration "qiskit.circuit.QuantumCircuit.duration") is specified in. + - 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. + ### op\_start\_times - **Parameters** + + Return a list of operation start times. - * **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. + This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. **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") + 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** - [**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 to new parameters or values. + [**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + - If `parameters` is passed as a dictionary, the keys should 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. + Finally, [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") exposes several simple properties as dynamic read-only numeric attributes. - 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). + ### num\_ancillas - The values can be assigned to the current circuit object or to a copy of it. + + Return the number of ancilla qubits. + - - When `parameters` is given as a mapping, it is permissible to have keys that are strings of the parameter names; these will be looked up using [`get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter"). You can also have keys that are [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") instances, and in this case, the dictionary value should be a sequence of values of the same length as the vector. + ### num\_clbits - If you use either of these cases, you must leave the setting `flat_input=False`; changing this to `True` enables the fast path, where all keys must be [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances. - + + Return number of classical bits. + - **Parameters** + ### num\_captured\_vars - * **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, or string keys, which will be converted to [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances using [`get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter"). - * **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. + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. - **Raises** + This is the length of the [`iter_captured_vars()`](#qiskit.circuit.QuantumCircuit.iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars") iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.QuantumCircuit.num_input_vars "qiskit.circuit.QuantumCircuit.num_input_vars") must be zero. + - * [**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. + ### num\_declared\_vars - **Returns** + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. - A copy of the circuit with bound parameters if `inplace` is False, otherwise None. + This is the length of the [`iter_declared_vars()`](#qiskit.circuit.QuantumCircuit.iter_declared_vars "qiskit.circuit.QuantumCircuit.iter_declared_vars") iterable. + - **Examples** + ### num\_input\_vars - Create a parameterized circuit and assign the parameters in-place. + + The number of real-time classical variables in the circuit marked as circuit inputs. - ```python - from qiskit.circuit import QuantumCircuit, Parameter + This is the length of the [`iter_input_vars()`](#qiskit.circuit.QuantumCircuit.iter_input_vars "qiskit.circuit.QuantumCircuit.iter_input_vars") iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.QuantumCircuit.num_captured_vars "qiskit.circuit.QuantumCircuit.num_captured_vars") must be zero. + - 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') - ``` + ### num\_parameters - ![../\_images/qiskit-circuit-QuantumCircuit-3\_00.png](/images/api/qiskit/qiskit-circuit-QuantumCircuit-3_00.png) + + The number of parameter objects in the circuit. + - ![../\_images/qiskit-circuit-QuantumCircuit-3\_01.png](/images/api/qiskit/qiskit-circuit-QuantumCircuit-3_01.png) + ### num\_qubits - Bind the values out-of-place by list and get a copy of the original circuit. + + Return number of qubits. + - ```python - from qiskit.circuit import QuantumCircuit, ParameterVector + ### num\_vars - circuit = QuantumCircuit(2) - params = ParameterVector('P', 2) - circuit.ry(params[0], 0) - circuit.crx(params[1], 0, 1) + + The number of real-time classical variables in the circuit. - bound_circuit = circuit.assign_parameters([1, 2]) - bound_circuit.draw('mpl') + This is the length of the [`iter_vars()`](#qiskit.circuit.QuantumCircuit.iter_vars "qiskit.circuit.QuantumCircuit.iter_vars") iterable. + - circuit.draw('mpl') - ``` + ## Creating new circuits - ![../\_images/qiskit-circuit-QuantumCircuit-4\_00.png](/images/api/qiskit/qiskit-circuit-QuantumCircuit-4_00.png) + | Method | Summary | + | --------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------- | + | [`__init__()`](#qiskit.circuit.QuantumCircuit.__init__ "qiskit.circuit.QuantumCircuit.__init__") | Default constructor of no-instruction circuits. | + | [`copy()`](#qiskit.circuit.QuantumCircuit.copy "qiskit.circuit.QuantumCircuit.copy") | Make a complete copy of an existing circuit. | + | [`copy_empty_like()`](#qiskit.circuit.QuantumCircuit.copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like") | Copy data objects from one circuit into a new one without any instructions. | + | [`from_instructions()`](#qiskit.circuit.QuantumCircuit.from_instructions "qiskit.circuit.QuantumCircuit.from_instructions") | Infer data objects needed from a list of instructions. | + | [`from_qasm_file()`](#qiskit.circuit.QuantumCircuit.from_qasm_file "qiskit.circuit.QuantumCircuit.from_qasm_file") | Legacy interface to [`qasm2.load()`](qasm2#qiskit.qasm2.load "qiskit.qasm2.load"). | + | [`from_qasm_str()`](#qiskit.circuit.QuantumCircuit.from_qasm_str "qiskit.circuit.QuantumCircuit.from_qasm_str") | Legacy interface to [`qasm2.loads()`](qasm2#qiskit.qasm2.loads "qiskit.qasm2.loads"). | - ![../\_images/qiskit-circuit-QuantumCircuit-4\_01.png](/images/api/qiskit/qiskit-circuit-QuantumCircuit-4_01.png) - + The default constructor (`QuantumCircuit(...)`) produces a circuit with no initial instructions. The arguments to the default constructor can be used to seed the circuit with quantum and classical data storage, and to provide a name, global phase and arbitrary metadata. All of these fields can be expanded later. - ### barrier + ### \_\_init\_\_ - - Apply [`Barrier`](qiskit.circuit.library.Barrier "qiskit.circuit.library.Barrier"). If `qargs` is empty, applies to all qubits in the circuit. + + Default constructor of [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). **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. + * **regs** ([*Register*](circuit#qiskit.circuit.Register "qiskit.circuit.Register") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| Sequence\[*[*Bit*](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit")*]*) – - **Returns** + The registers to be included in the circuit. - handle to the added instructions. + * If a list of [`Register`](circuit#qiskit.circuit.Register "qiskit.circuit.Register") objects, represents the [`QuantumRegister`](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") and/or [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") objects to include in the circuit. - **Return type** + For example: - [qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - + > * `QuantumCircuit(QuantumRegister(4))` + > * `QuantumCircuit(QuantumRegister(4), ClassicalRegister(3))` + > * `QuantumCircuit(QuantumRegister(4, 'qr0'), QuantumRegister(2, 'qr1'))` - ### break\_loop + * 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. - - Apply [`BreakLoopOp`](qiskit.circuit.BreakLoopOp "qiskit.circuit.BreakLoopOp"). + For example: - - 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. - + > * `QuantumCircuit(4) # A QuantumCircuit with 4 qubits` + > * `QuantumCircuit(4, 3) # A QuantumCircuit with 4 qubits and 3 classical bits` - **Returns** + * If a list of python lists containing [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") objects, a collection of [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") s to be added to the circuit. - A handle to the instruction created. + * **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – the name of the quantum circuit. If not set, an automatically generated string will be assigned. - **Raises** + * **global\_phase** (*ParameterValueType*) – The global phase of the circuit in radians. - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if this method was called within a builder context, but not contained within a loop. + * **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. 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. - **Return type** + * **inputs** (*Iterable\[*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")*]*) – any variables to declare as `input` runtime variables for this circuit. These should already be existing [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes that you build from somewhere else; if you need to create the inputs as well, use [`QuantumCircuit.add_input()`](#qiskit.circuit.QuantumCircuit.add_input "qiskit.circuit.QuantumCircuit.add_input"). The variables given in this argument will be passed directly to [`add_input()`](#qiskit.circuit.QuantumCircuit.add_input "qiskit.circuit.QuantumCircuit.add_input"). A circuit cannot have both `inputs` and `captures`. - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - + * **captures** (*Iterable\[*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")*]*) – any variables that that this circuit scope should capture from a containing scope. The variables given here will be passed directly to [`add_capture()`](#qiskit.circuit.QuantumCircuit.add_capture "qiskit.circuit.QuantumCircuit.add_capture"). A circuit cannot have both `inputs` and `captures`. - ### cast + * **declarations** (*Mapping\[*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")*,* [*expr.Expr*](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")*] | Iterable\[Tuple\[*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")*,* [*expr.Expr*](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")*]]*) – - - Best effort to cast value to type. Otherwise, returns the value. + any variables that this circuit should declare and initialize immediately. You can order this input so that later declarations depend on earlier ones (including inputs or captures). If you need to depend on values that will be computed later at runtime, use [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var") at an appropriate point in the circuit execution. - **Return type** + This argument is intended for convenient circuit initialization when you already have a set of created variables. The variables used here will be directly passed to [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var"), which you can use directly if this is the first time you are creating the variable. - *S* | *T* + **Raises** + + * [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the circuit name, if given, is not valid. + * [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if both `inputs` and `captures` are given. - ### cbit\_argument\_conversion + If you have an existing circuit, you can produce a copy of it using [`copy()`](#qiskit.circuit.QuantumCircuit.copy "qiskit.circuit.QuantumCircuit.copy"), including all its instructions. This is useful if you want to keep partial circuits while extending another, or to have a version you can mutate in-place while leaving the prior one intact. - - Converts several classical bit representations (such as indexes, range, etc.) into a list of classical bits. + ### copy + + + Copy the circuit. **Parameters** - **clbit\_representation** (*Object*) – representation to expand + **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** - Where each tuple is a classical bit. + a deepcopy of the current circuit, with the specified name **Return type** - List([tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ### ccx + Similarly, if you want a circuit that contains all the same data objects (bits, registers, variables, etc) but with none of the instructions, you can use [`copy_empty_like()`](#qiskit.circuit.QuantumCircuit.copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like"). This is quite common when you want to build up a new layer of a circuit to then use apply onto the back with [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose"), or to do a full rewrite of a circuit’s instructions. - - Apply [`CCXGate`](qiskit.circuit.library.CCXGate "qiskit.circuit.library.CCXGate"). + ### copy\_empty\_like - For the full matrix form of this gate, see the underlying gate documentation. + + Return a copy of self with the same structure but empty. - **Parameters** + That structure includes: - * **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. + * name, calibrations and other metadata + * global phase + * all the qubits and clbits, including the registers + * the realtime variables defined in the circuit, handled according to the `vars` keyword argument. - **Returns** + + If the circuit contains any local variable declarations (those added by the `declarations` argument to the circuit constructor, or using [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var")), they may be **uninitialized** in the output circuit. You will need to manually add store instructions for them (see [`Store`](circuit#qiskit.circuit.Store "qiskit.circuit.Store") and [`QuantumCircuit.store()`](#qiskit.circuit.QuantumCircuit.store "qiskit.circuit.QuantumCircuit.store")) to initialize them. + - A handle to the instructions created. + **Parameters** - **Return type** + * **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name for the copied circuit. If None, then the name stays the same. - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - + * **vars\_mode** (*Literal\['alike', 'captures', 'drop']*) – - ### ccz + The mode to handle realtime variables in. - - Apply [`CCZGate`](qiskit.circuit.library.CCZGate "qiskit.circuit.library.CCZGate"). + **alike** - For the full matrix form of this gate, see the underlying gate documentation. + The variables in the output circuit will have the same declaration semantics as in the original circuit. For example, `input` variables in the source will be `input` variables in the output circuit. - **Parameters** + **captures** - * **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. + All variables will be converted to captured variables. This is useful when you are building a new layer for an existing circuit that you will want to [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") onto the base, since [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") can inline captures onto the base circuit (but not other variables). + + **drop** + + The output circuit will have no variables defined. **Returns** - A handle to the instructions created. + An empty copy of self. **Return type** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ### ch + In some cases, it is most convenient to generate a list of [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s separately to an entire circuit context, and then to build a circuit from this. The [`from_instructions()`](#qiskit.circuit.QuantumCircuit.from_instructions "qiskit.circuit.QuantumCircuit.from_instructions") constructor will automatically capture all [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit") and [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") instances used in the instructions, and create a new [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") object that has the correct resources and all the instructions. - - Apply [`CHGate`](qiskit.circuit.library.CHGate "qiskit.circuit.library.CHGate"). + ### from\_instructions - For the full matrix form of this gate, see the underlying gate documentation. + + Construct a circuit from an iterable of [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s. **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. + * **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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*], Iterable\[*[*Clbit*](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit")*]]]*) – The instructions to add to the circuit. + * **qubits** (*Iterable\[*[*Qubit*](circuit#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*](circuit#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** - A handle to the instructions created. + The quantum circuit. **Return type** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ### clear - - - Clear all instructions in self. - - Clearing the circuits will keep the metadata and calibrations. - + [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") also still has two constructor methods that are legacy wrappers around the importers in [`qiskit.qasm2`](qasm2#module-qiskit.qasm2 "qiskit.qasm2"). These automatically apply [the legacy compatibility settings](qasm2#qasm2-legacy-compatibility) of [`load()`](qasm2#qiskit.qasm2.load "qiskit.qasm2.load") and [`loads()`](qasm2#qiskit.qasm2.loads "qiskit.qasm2.loads"). - ### cls\_instances + ### from\_qasm\_file - - Return the current number of instances of this class, useful for auto naming. + + Read an OpenQASM 2.0 program from a file and convert to an instance of [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). - **Return type** + **Parameters** - [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") - + **path** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Path to the file for an OpenQASM 2 program - ### cls\_prefix + **Returns** - - Return the prefix to use for auto naming. + The QuantumCircuit object for the input OpenQASM 2. **Return type** - [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") - + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ### compose + + [`qasm2.load()`](qasm2#qiskit.qasm2.load "qiskit.qasm2.load"): the complete interface to the OpenQASM 2 importer. + + - - Compose circuit with `other` circuit or instruction, optionally permuting wires. + ### from\_qasm\_str - `other` can be narrower or of equal width to `self`. + + Convert a string containing an OpenQASM 2.0 program to a [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). **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. + **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 composed circuit (returns None if inplace==True). + The QuantumCircuit object for the input OpenQASM 2 **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. + + [`qasm2.loads()`](qasm2#qiskit.qasm2.loads "qiskit.qasm2.loads"): the complete interface to the OpenQASM 2 importer. + + - **Examples** + ## Data objects on circuits - ```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 ═══════════════════════ + ### Adding data objects - lcr_1: 0 ═══════════ lcr_1: 0 ═══════════════════════ - ``` - + | Method | Adds this kind of data | + | --------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | + | [`add_bits()`](#qiskit.circuit.QuantumCircuit.add_bits "qiskit.circuit.QuantumCircuit.add_bits") | [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")s and [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit")s. | + | [`add_register()`](#qiskit.circuit.QuantumCircuit.add_register "qiskit.circuit.QuantumCircuit.add_register") | [`QuantumRegister`](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") and [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister"). | + | [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var") | [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes with local scope and initializers. | + | [`add_input()`](#qiskit.circuit.QuantumCircuit.add_input "qiskit.circuit.QuantumCircuit.add_input") | [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes that are treated as circuit inputs. | + | [`add_capture()`](#qiskit.circuit.QuantumCircuit.add_capture "qiskit.circuit.QuantumCircuit.add_capture") | [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes captured from containing scopes. | + | [`add_uninitialized_var()`](#qiskit.circuit.QuantumCircuit.add_uninitialized_var "qiskit.circuit.QuantumCircuit.add_uninitialized_var") | [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes with local scope and undefined state. | - ### continue\_loop + Typically you add most of the data objects ([`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit"), [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit"), [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister"), etc) to the circuit as part of using the [`__init__()`](#qiskit.circuit.QuantumCircuit.__init__ "qiskit.circuit.QuantumCircuit.__init__") default constructor, or [`copy_empty_like()`](#qiskit.circuit.QuantumCircuit.copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like"). However, it is also possible to add these afterwards. Typed classical data, such as standalone [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes (see [Real-time classical computation](circuit#circuit-repr-real-time-classical)), can be both constructed and added with separate methods. - - Apply [`ContinueLoopOp`](qiskit.circuit.ContinueLoopOp "qiskit.circuit.ContinueLoopOp"). + New registerless [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit") and [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") objects are added using [`add_bits()`](#qiskit.circuit.QuantumCircuit.add_bits "qiskit.circuit.QuantumCircuit.add_bits"). These objects must not already be present in the circuit. You can check if a bit exists in the circuit already using [`find_bit()`](#qiskit.circuit.QuantumCircuit.find_bit "qiskit.circuit.QuantumCircuit.find_bit"). - - 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. - + #### add\_bits - **Returns** + + Add Bits to the circuit. + - A handle to the instruction created. + Registers are added to the circuit with [`add_register()`](#qiskit.circuit.QuantumCircuit.add_register "qiskit.circuit.QuantumCircuit.add_register"). In this method, it is not an error if some of the bits are already present in the circuit. In this case, the register will be an “alias” over the bits. This is not generally well-supported by hardware backends; it is probably best to stay away from relying on it. The registers a given bit is in are part of the return of [`find_bit()`](#qiskit.circuit.QuantumCircuit.find_bit "qiskit.circuit.QuantumCircuit.find_bit"). - **Raises** + #### add\_register - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if this method was called within a builder context, but not contained within a loop. + + Add registers. + - **Return type** + [Real-time, typed classical data](circuit#circuit-repr-real-time-classical) is represented on the circuit by [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes with a well-defined [`Type`](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type"). It is possible to instantiate these separately to a circuit (see [`Var.new()`](circuit_classical#qiskit.circuit.classical.expr.Var.new "qiskit.circuit.classical.expr.Var.new")), but it is often more convenient to use circuit methods that will automatically manage the types and expression initialization for you. The two most common methods are [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var") (locally scoped variables) and [`add_input()`](#qiskit.circuit.QuantumCircuit.add_input "qiskit.circuit.QuantumCircuit.add_input") (inputs to the circuit). - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - + #### add\_var - ### control + + Add a classical variable with automatic storage and scope to this circuit. - - Control this circuit on `num_ctrl_qubits` qubits. + The variable is considered to have been “declared” at the beginning of the circuit, but it only becomes initialized at the point of the circuit that you call this method, so it can depend on variables defined before it. **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`. - * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + * **name\_or\_var** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")) – either a string of the variable name, or an existing instance of [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") to re-use. Variables cannot shadow names that are already in use within the circuit. - **Returns** + * **initial** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – - The controlled version of this circuit. + the value to initialize this variable with. If the first argument was given as a string name, the type of the resulting variable is inferred from the initial expression; to control this more manually, either use [`Var.new()`](circuit_classical#qiskit.circuit.classical.expr.Var.new "qiskit.circuit.classical.expr.Var.new") to manually construct a new variable with the desired type, or use [`expr.cast()`](circuit_classical#qiskit.circuit.classical.expr.cast "qiskit.circuit.classical.expr.cast") to cast the initializer to the desired type. - **Return type** + This must be either a [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") node, or a value that can be lifted to one using `expr.lift`. - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + **Returns** + + The created variable. If a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instance was given, the exact same object will be returned. **Raises** - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the circuit contains a non-unitary operation and cannot be controlled. - + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the variable cannot be created due to shadowing an existing variable. - ### copy + **Return type** - - Copy the circuit. + [expr.Var](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") - **Parameters** + **Examples** - **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. + Define a new variable given just a name and an initializer expression: - **Returns** + ```python + from qiskit.circuit import QuantumCircuit - a deepcopy of the current circuit, with the specified name + qc = QuantumCircuit(2) + my_var = qc.add_var("my_var", False) + ``` - **Return type** + Reuse a variable that may have been taken from a related circuit, or otherwise constructed manually, and initialize it to some more complicated expression: - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - + ```python + from qiskit.circuit import QuantumCircuit, QuantumRegister, ClassicalRegister + from qiskit.circuit.classical import expr, types - ### copy\_empty\_like + my_var = expr.Var.new("my_var", types.Uint(8)) - - Return a copy of self with the same structure but empty. + cr1 = ClassicalRegister(8, "cr1") + cr2 = ClassicalRegister(8, "cr2") + qc = QuantumCircuit(QuantumRegister(8), cr1, cr2) - **That structure includes:** + # Get some measurement results into each register. + qc.h(0) + for i in range(1, 8): + qc.cx(0, i) + qc.measure(range(8), cr1) - * name, calibrations and other metadata - * global phase - * all the qubits and clbits, including the registers + qc.reset(range(8)) + qc.h(0) + for i in range(1, 8): + qc.cx(0, i) + qc.measure(range(8), cr2) + + # Now when we add the variable, it is initialized using the real-time state of the + # two classical registers we measured into above. + qc.add_var(my_var, expr.bit_and(cr1, cr2)) + ``` + + + #### add\_input + + + Register a variable as an input to the circuit. **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. + * **name\_or\_var** – either a string name, or an existing [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node to use as the input variable. + * **type** – if the name is given as a string, then this must be a [`Type`](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type") to use for the variable. If the variable is given as an existing [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var"), then this must not be given, and will instead be read from the object itself. **Returns** - An empty copy of self. + the variable created, or the same variable as was passed in. - **Return type** + **Raises** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the variable cannot be created due to shadowing an existing variable. - ### count\_ops + In addition, there are two lower-level methods that can be useful for programmatic generation of circuits. When working interactively, you will most likely not need these; most uses of [`add_uninitialized_var()`](#qiskit.circuit.QuantumCircuit.add_uninitialized_var "qiskit.circuit.QuantumCircuit.add_uninitialized_var") are part of [`copy_empty_like()`](#qiskit.circuit.QuantumCircuit.copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like"), and most uses of [`add_capture()`](#qiskit.circuit.QuantumCircuit.add_capture "qiskit.circuit.QuantumCircuit.add_capture") would be better off using [the control-flow builder interface](#circuit-control-flow-methods). - - Count each operation kind in the circuit. + #### add\_uninitialized\_var - **Returns** + + Add a variable with no initializer. - a breakdown of how many operations of each kind, sorted by amount. + In most cases, you should use [`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var") to initialize the variable. To use this function, you must already hold a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instance, as the use of the function typically only makes sense in copying contexts. - **Return type** + + Qiskit makes no assertions about what an uninitialized variable will evaluate to at runtime, and some hardware may reject this as an error. - OrderedDict + You should treat this function with caution, and as a low-level primitive that is useful only in special cases of programmatically rebuilding two like circuits. + + + **Parameters** + + **var** ([*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")) – the variable to add. - ### cp + #### add\_capture - - Apply [`CPhaseGate`](qiskit.circuit.library.CPhaseGate "qiskit.circuit.library.CPhaseGate"). + + Add a variable to the circuit that it should capture from a scope it will be contained within. - For the full matrix form of this gate, see the underlying gate documentation. + This method requires a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node to enforce that you’ve got a handle to one, because you will need to declare the same variable using the same object into the outer circuit. + + This is a low-level method, which is only really useful if you are manually constructing control-flow operations. You typically will not need to call this method, assuming you are using the builder interface for control-flow scopes (`with` context-manager statements for [`if_test()`](#qiskit.circuit.QuantumCircuit.if_test "qiskit.circuit.QuantumCircuit.if_test") and the other scoping constructs). The builder interface will automatically make the inner scopes closures on your behalf by capturing any variables that are used within them. **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. + **var** ([*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")) – the variable to capture from an enclosing scope. - **Returns** + **Raises** - A handle to the instructions created. + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the variable cannot be created due to shadowing an existing variable. + - **Return type** + ### Working with bits and registers - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - + A [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") instance is, on its own, just a unique handle for circuits to use in their own contexts. If you have got a [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") instance and a cirucit, just can find the contexts that the bit exists in using [`find_bit()`](#qiskit.circuit.QuantumCircuit.find_bit "qiskit.circuit.QuantumCircuit.find_bit"), such as its integer index in the circuit and any registers it is contained in. - ### crx + #### find\_bit - - Apply [`CRXGate`](qiskit.circuit.library.CRXGate "qiskit.circuit.library.CRXGate"). + + Find locations in the circuit which can be used to reference a given [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit"). - For the full matrix form of this gate, see the underlying gate documentation. + In particular, this function can find the integer index of a qubit, which corresponds to its hardware index for a transpiled circuit. + + + The circuit index of a [`AncillaQubit`](circuit#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"). + **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. + **bit** ([*Bit*](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit")) – The bit to locate. **Returns** - A handle to the instructions created. + 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`](circuit#qiskit.circuit.Register "qiskit.circuit.Register") in the circuit which contains the [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") (and the index in the [`Register`](circuit#qiskit.circuit.Register "qiskit.circuit.Register") at which it can be found). **Return type** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - - - ### cry - - - Apply [`CRYGate`](qiskit.circuit.library.CRYGate "qiskit.circuit.library.CRYGate"). + namedtuple([int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"), List\[Tuple([Register](circuit#qiskit.circuit.Register "qiskit.circuit.Register"), [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"))]) - For the full matrix form of this gate, see the underlying gate documentation. + **Raises** - **Parameters** + * [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the supplied [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") was of an unknown type. + * [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the supplied [`Bit`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") could not be found on the circuit. - * **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. + **Examples** - **Returns** + Loop through a circuit, getting the qubit and clbit indices of each operation: - A handle to the instructions created. + ```python + from qiskit.circuit import QuantumCircuit, Qubit - **Return type** + qc = QuantumCircuit(3, 3) + qc.h(0) + qc.cx(0, 1) + qc.cx(1, 2) + qc.measure([0, 1, 2], [0, 1, 2]) - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + # The `.qubits` and `.clbits` fields are not integers. + assert isinstance(qc.data[0].qubits[0], Qubit) + # ... but we can use `find_bit` to retrieve them. + assert qc.find_bit(qc.data[0].qubits[0]).index == 0 + + simple = [ + ( + instruction.operation.name, + [qc.find_bit(bit).index for bit in instruction.qubits], + [qc.find_bit(bit).index for bit in instruction.clbits], + ) + for instruction in qc.data + ] + ``` - ### crz + Similarly, you can query a circuit to see if a register has already been added to it by using [`has_register()`](#qiskit.circuit.QuantumCircuit.has_register "qiskit.circuit.QuantumCircuit.has_register"). - - Apply [`CRZGate`](qiskit.circuit.library.CRZGate "qiskit.circuit.library.CRZGate"). + #### has\_register - For the full matrix form of this gate, see the underlying gate documentation. + + Test if this circuit has the register r. **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. + **register** ([*Register*](circuit#qiskit.circuit.Register "qiskit.circuit.Register")) – a quantum or classical register. **Returns** - A handle to the instructions created. + True if the register is contained in this circuit. **Return type** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") - ### cs + ### Working with compile-time parameters - - Apply [`CSGate`](qiskit.circuit.library.CSGate "qiskit.circuit.library.CSGate"). + + **[Compile-time parametrization](circuit#circuit-compile-time-parameters)** - For the full matrix form of this gate, see the underlying gate documentation. + A more complete discussion of what compile-time parametrization is, and how it fits into Qiskit’s data model. + - **Parameters** + Unlike bits, registers, and real-time typed classical data, compile-time symbolic parameters are not manually added to a circuit. Their presence is inferred by being contained in operations added to circuits and the global phase. An ordered list of all parameters currently in a circuit is at [`QuantumCircuit.parameters`](#qiskit.circuit.QuantumCircuit.parameters "qiskit.circuit.QuantumCircuit.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. + The most common operation on [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances is to replace them in symbolic operations with some numeric value, or another symbolic expression. This is done with [`assign_parameters()`](#qiskit.circuit.QuantumCircuit.assign_parameters "qiskit.circuit.QuantumCircuit.assign_parameters"). - **Returns** + #### assign\_parameters - A handle to the instructions created. + + Assign parameters to new parameters or values. - **Return type** + If `parameters` is passed as a dictionary, the keys should 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. - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - + 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). - ### csdg + The values can be assigned to the current circuit object or to a copy of it. - - Apply [`CSdgGate`](qiskit.circuit.library.CSdgGate "qiskit.circuit.library.CSdgGate"). + + When `parameters` is given as a mapping, it is permissible to have keys that are strings of the parameter names; these will be looked up using [`get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter"). You can also have keys that are [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") instances, and in this case, the dictionary value should be a sequence of values of the same length as the vector. - For the full matrix form of this gate, see the underlying gate documentation. + If you use either of these cases, you must leave the setting `flat_input=False`; changing this to `True` enables the fast path, where all keys must be [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances. + **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. + * **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, or string keys, which will be converted to [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances using [`get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter"). + * **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 handle to the instructions created. + A copy of the circuit with bound parameters if `inplace` is False, otherwise None. - **Return type** + **Examples** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - + Create a parameterized circuit and assign the parameters in-place. - ### cswap + ```python + from qiskit.circuit import QuantumCircuit, Parameter - - Apply [`CSwapGate`](qiskit.circuit.library.CSwapGate "qiskit.circuit.library.CSwapGate"). + 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') + ``` - For the full matrix form of this gate, see the underlying gate documentation. + ![../\_images/qiskit-circuit-QuantumCircuit-1\_00.png](/images/api/qiskit/qiskit-circuit-QuantumCircuit-1_00.png) - **Parameters** + ![../\_images/qiskit-circuit-QuantumCircuit-1\_01.png](/images/api/qiskit/qiskit-circuit-QuantumCircuit-1_01.png) - * **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. + Bind the values out-of-place by list and get a copy of the original circuit. - **Returns** + ```python + from qiskit.circuit import QuantumCircuit, ParameterVector - A handle to the instructions created. + circuit = QuantumCircuit(2) + params = ParameterVector('P', 2) + circuit.ry(params[0], 0) + circuit.crx(params[1], 0, 1) - **Return type** + bound_circuit = circuit.assign_parameters([1, 2]) + bound_circuit.draw('mpl') - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + circuit.draw('mpl') + ``` + + ![../\_images/qiskit-circuit-QuantumCircuit-2\_00.png](/images/api/qiskit/qiskit-circuit-QuantumCircuit-2_00.png) + + ![../\_images/qiskit-circuit-QuantumCircuit-2\_01.png](/images/api/qiskit/qiskit-circuit-QuantumCircuit-2_01.png) - ### csx + The circuit tracks parameters by [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances themselves, and forbids having multiple parameters of the same name to avoid some problems when interoperating with OpenQASM or other external formats. You can use [`has_parameter()`](#qiskit.circuit.QuantumCircuit.has_parameter "qiskit.circuit.QuantumCircuit.has_parameter") and [`get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter") to query the circuit for a parameter with the given string name. - - Apply [`CSXGate`](qiskit.circuit.library.CSXGate "qiskit.circuit.library.CSXGate"). + #### has\_parameter - For the full matrix form of this gate, see the underlying gate documentation. + + Check whether a parameter object exists in this circuit. **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. + **name\_or\_param** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")) – the parameter, or name of a parameter to check. If this is a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") node, the parameter must be exactly the given one for this function to return `True`. **Returns** - A handle to the instructions created. + whether a matching parameter is assignable in this circuit. **Return type** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + **[`QuantumCircuit.get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter")** - ### cu + Retrieve the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instance from this circuit by name. - - Apply [`CUGate`](qiskit.circuit.library.CUGate "qiskit.circuit.library.CUGate"). + **[`QuantumCircuit.has_var()`](#qiskit.circuit.QuantumCircuit.has_var "qiskit.circuit.QuantumCircuit.has_var")** - For the full matrix form of this gate, see the underlying gate documentation. + A similar method to this, but for run-time [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") variables instead of compile-time [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")s. + + + + #### get\_parameter + + + Retrieve a compile-time parameter that is accessible in this circuit scope by name. **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. + * **name** – the name of the parameter to retrieve. + * **default** – if given, this value will be returned if the parameter is not present. If it is not given, a [`KeyError`](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") is raised instead. **Returns** - A handle to the instructions created. + The corresponding parameter. - **Return type** + **Raises** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - + [**KeyError**](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") – if no default is given, but the parameter does not exist in the circuit. - ### cx + **Examples** - - Apply [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate"). + Retrieve a parameter by name from a circuit: - For the full matrix form of this gate, see the underlying gate documentation. + ```python + from qiskit.circuit import QuantumCircuit, Parameter - **Parameters** + my_param = Parameter("my_param") - * **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. + # Create a parametrised circuit. + qc = QuantumCircuit(1) + qc.rx(my_param, 0) - **Returns** + # We can use 'my_param' as a parameter, but let's say we've lost the Python object + # and need to retrieve it. + my_param_again = qc.get_parameter("my_param") - A handle to the instructions created. + assert my_param is my_param_again + ``` - **Return type** + Get a variable from a circuit by name, returning some default if it is not present: - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - + ```python + assert qc.get_parameter("my_param", None) is my_param + assert qc.get_parameter("unknown_param", None) is None + ``` - ### cy + + **[`get_var()`](#qiskit.circuit.QuantumCircuit.get_var "qiskit.circuit.QuantumCircuit.get_var")** - - Apply [`CYGate`](qiskit.circuit.library.CYGate "qiskit.circuit.library.CYGate"). + A similar method, but for [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") run-time variables instead of [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") compile-time parameters. + + - For the full matrix form of this gate, see the underlying gate documentation. + - **Parameters** + ### Working with real-time typed classical data - * **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. + + **[`qiskit.circuit.classical`](circuit_classical#module-qiskit.circuit.classical "qiskit.circuit.classical")** - **Returns** + Module-level documentation for how the variable-, expression- and type-systems work, the objects used to represent them, and the classical operations available. - A handle to the instructions created. + **[Real-time classical computation](circuit#circuit-repr-real-time-classical)** - **Return type** + A discussion of how real-time data fits into the entire [`qiskit.circuit`](circuit#module-qiskit.circuit "qiskit.circuit") data model as a whole. - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - + **[Adding data objects](#circuit-adding-data-objects)** - ### cz + The methods for adding new [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") variables to a circuit after initialization. + - - Apply [`CZGate`](qiskit.circuit.library.CZGate "qiskit.circuit.library.CZGate"). + You can retrive a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instance attached to a circuit by using its variable name using [`get_var()`](#qiskit.circuit.QuantumCircuit.get_var "qiskit.circuit.QuantumCircuit.get_var"), or check if a circuit contains a given variable with [`has_var()`](#qiskit.circuit.QuantumCircuit.has_var "qiskit.circuit.QuantumCircuit.has_var"). - For the full matrix form of this gate, see the underlying gate documentation. + #### get\_var + + + Retrieve a variable that is accessible in this circuit scope by name. **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. + * **name** – the name of the variable to retrieve. + * **default** – if given, this value will be returned if the variable is not present. If it is not given, a [`KeyError`](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") is raised instead. **Returns** - A handle to the instructions created. + The corresponding variable. - **Return type** + **Raises** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - + [**KeyError**](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") – if no default is given, but the variable does not exist. - ### dcx + **Examples** - - Apply [`DCXGate`](qiskit.circuit.library.DCXGate "qiskit.circuit.library.DCXGate"). + Retrieve a variable by name from a circuit: - For the full matrix form of this gate, see the underlying gate documentation. + ```python + from qiskit.circuit import QuantumCircuit - **Parameters** + # Create a circuit and create a variable in it. + qc = QuantumCircuit() + my_var = qc.add_var("my_var", False) - * **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. + # We can use 'my_var' as a variable, but let's say we've lost the Python object and + # need to retrieve it. + my_var_again = qc.get_var("my_var") - **Returns** + assert my_var is my_var_again + ``` - A handle to the instructions created. + Get a variable from a circuit by name, returning some default if it is not present: - **Return type** + ```python + assert qc.get_var("my_var", None) is my_var + assert qc.get_var("unknown_variable", None) is None + ``` - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + + **[`get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter")** + + A similar method, but for [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") compile-time parameters instead of [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") run-time variables. + - ### decompose + #### has\_var - - Call a decomposition pass on this circuit, to decompose one level (shallow decompose). + + Check whether a variable is accessible in this scope. **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 + **name\_or\_var** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")) – the variable, or name of a variable to check. If this is a [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node, the variable must be exactly the given one for this function to return `True`. **Returns** - a circuit one level decomposed + whether a matching variable is accessible. **Return type** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") - ### delay + + **[`QuantumCircuit.get_var()`](#qiskit.circuit.QuantumCircuit.get_var "qiskit.circuit.QuantumCircuit.get_var")** - - 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. + Retrieve the [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instance from this circuit by name. - **Parameters** + **[`QuantumCircuit.has_parameter()`](#qiskit.circuit.QuantumCircuit.has_parameter "qiskit.circuit.QuantumCircuit.has_parameter")** - * **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. + A similar method to this, but for compile-time [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")s instead of run-time [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") variables. + + - **Returns** + There are also several iterator methods that you can use to get the full set of variables tracked by a circuit. At least one of [`iter_input_vars()`](#qiskit.circuit.QuantumCircuit.iter_input_vars "qiskit.circuit.QuantumCircuit.iter_input_vars") and [`iter_captured_vars()`](#qiskit.circuit.QuantumCircuit.iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars") will be empty, as inputs and captures are mutually exclusive. All of the iterators have corresponding dynamic properties on [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") that contain their length: [`num_vars`](#qiskit.circuit.QuantumCircuit.num_vars "qiskit.circuit.QuantumCircuit.num_vars"), [`num_input_vars`](#qiskit.circuit.QuantumCircuit.num_input_vars "qiskit.circuit.QuantumCircuit.num_input_vars"), [`num_captured_vars`](#qiskit.circuit.QuantumCircuit.num_captured_vars "qiskit.circuit.QuantumCircuit.num_captured_vars") and [`num_declared_vars`](#qiskit.circuit.QuantumCircuit.num_declared_vars "qiskit.circuit.QuantumCircuit.num_declared_vars"). - handle to the added instructions. + #### iter\_vars - **Return type** + + Get an iterable over all real-time classical variables in scope within this circuit. - [qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + This method will iterate over all variables in scope. For more fine-grained iterators, see [`iter_declared_vars()`](#qiskit.circuit.QuantumCircuit.iter_declared_vars "qiskit.circuit.QuantumCircuit.iter_declared_vars"), [`iter_input_vars()`](#qiskit.circuit.QuantumCircuit.iter_input_vars "qiskit.circuit.QuantumCircuit.iter_input_vars") and [`iter_captured_vars()`](#qiskit.circuit.QuantumCircuit.iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars"). - **Raises** + **Return type** - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if arguments have bad format. + [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")] - ### depth + #### iter\_input\_vars - - Return circuit depth (i.e., length of critical path). + + Get an iterable over all real-time classical variables that are declared as inputs to this circuit scope. This excludes locally declared variables (see [`iter_declared_vars()`](#qiskit.circuit.QuantumCircuit.iter_declared_vars "qiskit.circuit.QuantumCircuit.iter_declared_vars")) and captured variables (see [`iter_captured_vars()`](#qiskit.circuit.QuantumCircuit.iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars")). - **Parameters** + **Return type** - **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. + [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")] + - **Returns** + #### iter\_captured\_vars - Depth of circuit. + + Get an iterable over all real-time classical variables that are captured by this circuit scope from a containing scope. This excludes input variables (see [`iter_input_vars()`](#qiskit.circuit.QuantumCircuit.iter_input_vars "qiskit.circuit.QuantumCircuit.iter_input_vars")) and locally declared variables (see [`iter_declared_vars()`](#qiskit.circuit.QuantumCircuit.iter_declared_vars "qiskit.circuit.QuantumCircuit.iter_declared_vars")). **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. + [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")] - ### draw + #### iter\_declared\_vars - - Draw the quantum circuit. Use the output parameter to choose the drawing format: + + Get an iterable over all real-time classical variables that are declared with automatic storage duration in this scope. This excludes input variables (see [`iter_input_vars()`](#qiskit.circuit.QuantumCircuit.iter_input_vars "qiskit.circuit.QuantumCircuit.iter_input_vars")) and captured variables (see [`iter_captured_vars()`](#qiskit.circuit.QuantumCircuit.iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars")). - **text**: ASCII art TextDrawing that can be printed in the console. + **Return type** - **mpl**: images with color rendered purely in Python using matplotlib. + [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")] + - **latex**: high-quality images compiled via latex. + - **latex\_source**: raw uncompiled latex output. + ## Adding operations to circuits - - 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. - + You can add anything that implements the [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") interface to a circuit as a single instruction, though most things you will want to add will be [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") or [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") instances. - **Parameters** + + **[Operations, instructions and gates](circuit#circuit-operations-instructions)** - * **output** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – 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. + The [`qiskit.circuit`](circuit#module-qiskit.circuit "qiskit.circuit")-level documentation on the different interfaces that Qiskit uses to define circuit-level instructions. + - * **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – 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)") *| None*) – File path to save image to. Defaults to `None` (result not saved in a file). + ### Methods to add general operations - * **style** ([*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)") *| None*) – + These are the base methods that handle adding any object, including user-defined ones, onto circuits. - Style name, file name of style JSON file, or a dictionary specifying the style. + | Method | When to use it | + | --------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------- | + | [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") | Add an instruction as a single object onto a circuit. | + | [`_append()`](#qiskit.circuit.QuantumCircuit._append "qiskit.circuit.QuantumCircuit._append") | Same as [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append"), but a low-level interface that elides almost all error checking. | + | [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") | Inline the instructions from one circuit onto another. | + | [`tensor()`](#qiskit.circuit.QuantumCircuit.tensor "qiskit.circuit.QuantumCircuit.tensor") | Like [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose"), but strictly for joining circuits that act on disjoint qubits. | - * The supported style names are `"iqp"` (default), `"iqp-dark"`, `"clifford"`, `"textbook"` and `"bw"`. - * If given a JSON file, e.g. `my_style.json` or `my_style` (the `.json` extension may be omitted), this function attempts to load the style dictionary from that location. Note, that the JSON file must completely specify the visualization specifications. The file is searched for in `qiskit/visualization/circuit/styles`, the current working directory, and the location specified in `~/.qiskit/settings.conf`. - * If a dictionary, every entry overrides the default configuration. If the `"name"` key is given, the default configuration is given by that style. For example, `{"name": "textbook", "subfontsize": 5}` loads the `"texbook"` style and sets the subfontsize (e.g. the gate angles) to `5`. - * If `None` the default style `"iqp"` is used or, if given, the default style specified in `~/.qiskit/settings.conf`. + [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") has two main ways that you will add more operations onto a circuit. Which to use depends on whether you want to add your object as a single “instruction” ([`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append")), or whether you want to join the instructions from two circuits together ([`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose")). - * **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`. + A single instruction or operation appears as a single entry in the [`data`](#qiskit.circuit.QuantumCircuit.data "qiskit.circuit.QuantumCircuit.data") of the circuit, and as a single box when drawn in the circuit visualizers (see [`draw()`](#qiskit.circuit.QuantumCircuit.draw "qiskit.circuit.QuantumCircuit.draw")). A single instruction is the “unit” that a hardware backend might be defined in terms of (see [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target")). An [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") can come with a [`definition`](qiskit.circuit.Instruction#definition "qiskit.circuit.Instruction.definition"), which is one rule the transpiler (see [`qiskit.transpiler`](transpiler#module-qiskit.transpiler "qiskit.transpiler")) will be able to fall back on to decompose it for hardware, if needed. An [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") that is not also an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") can only be decomposed if it has some associated high-level synthesis method registered for it (see [`qiskit.transpiler.passes.synthesis.plugin`](transpiler_synthesis_plugins#module-qiskit.transpiler.passes.synthesis.plugin "qiskit.transpiler.passes.synthesis.plugin")). - * **reverse\_bits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – 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`. + A [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") alone is not a single [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"); it is rather more complicated, since it can, in general, represent a complete program with typed classical memory inputs and outputs, and control flow. Qiskit’s (and most hardware’s) data model does not yet have the concept of re-usable callable subroutines with virtual quantum operands. You can convert simple circuits that act only on qubits with unitary operations into a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") using [`to_gate()`](#qiskit.circuit.QuantumCircuit.to_gate "qiskit.circuit.QuantumCircuit.to_gate"), and simple circuits acting only on qubits and clbits into a [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") with [`to_instruction()`](#qiskit.circuit.QuantumCircuit.to_instruction "qiskit.circuit.QuantumCircuit.to_instruction"). - * **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`. + When you have an [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation"), [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"), or [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"), add it to the circuit, specifying the qubit and clbit arguments with [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append"). - * **justify** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – 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. + #### append - * **vertical\_compression** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – `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. + + Append one or more instructions to the end of the circuit, modifying the circuit in place. - * **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`. + 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`](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit") specifiers (such as integer indices) will be resolved into the relevant instances. - * **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`. + 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. - * **fold** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – 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. + **Parameters** - * **ax** (*Any | None*) – Only used by the mpl backend. An optional `matplotlib.axes.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. + * **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`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")s to attach instruction to. + * **cargs** (*Sequence\[ClbitSpecifier] | None*) – specifiers of the [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit")s to attach instruction to. + * **copy** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if `True` (the default), then the incoming `instruction` is copied before adding it to the circuit if it contains symbolic parameters, so it can be safely mutated without affecting other circuits the same instruction might be in. If you are sure this instruction will not be in other circuits, you can set this `False` for a small speedup. - * **initial\_state** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Adds $|0\rangle$ in the beginning of the qubit wires and $0$ to classical wires. Default is `False`. + **Returns** - * **cregbundle** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If set to `True`, bundle classical registers. Default is `True`, except for when `output` is set to `"text"`. + a handle to the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s that were actually added to the circuit. - * **wire\_order** ([*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 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`). + **Return type** - * **expr\_len** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – 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. + [qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - **Returns** + **Raises** - `TextDrawing` or `matplotlib.figure` or `PIL.Image` or [`str`](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"): + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the operation passed is not an instance of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") . + - * **`TextDrawing` (if `output='text'`)** + [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") does quite substantial error checking to ensure that you cannot accidentally break the data model of [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). If you are programmatically generating a circuit from known-good data, you can elide much of this error checking by using the fast-path appender [`_append()`](#qiskit.circuit.QuantumCircuit._append "qiskit.circuit.QuantumCircuit._append"), but at the risk that the caller is responsible for ensuring they are passing only valid data. - A drawing that can be printed as ascii art. + #### \_append - * **`matplotlib.figure.Figure` (if `output='mpl'`)** + + Append an instruction to the end of the circuit, modifying the circuit in place. - A matplotlib figure object for the circuit diagram. + + This is an internal fast-path function, and it is the responsibility of the caller to ensure that all the arguments are valid; there is no error checking here. In particular: - * **`PIL.Image` (if `output='latex`’)** + * all the qubits and clbits must already exist in the circuit and there can be no duplicates in the list. + * any control-flow operations or classically conditioned instructions must act only on variables present in the circuit. + * the circuit must not be within a control-flow builder context. + - An in-memory representation of the image of the circuit diagram. + + This function may be used by callers other than [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") when the caller is sure that all error-checking, broadcasting and scoping has already been performed, and the only reference to the circuit the instructions are being appended to is within that same function. In particular, it is not safe to call [`QuantumCircuit._append()`](#qiskit.circuit.QuantumCircuit._append "qiskit.circuit.QuantumCircuit._append") on a circuit that is received by a function argument. This is because [`QuantumCircuit._append()`](#qiskit.circuit.QuantumCircuit._append "qiskit.circuit.QuantumCircuit._append") will not recognise the scoping constructs of the control-flow builder interface. + - * **`str` (if `output='latex_source'`)** + **Parameters** - The LaTeX source code for visualizing the circuit diagram. + * **instruction** – - **Raises** + A complete well-formed [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") of the operation and its context to be added. - * [**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. + In the legacy compatibility form, this can be a bare [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation"), in which case `qargs` and `cargs` must be explicitly given. - **Example** + * **qargs** – Legacy argument for qubits to attach the bare [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") to. Ignored if the first argument is in the preferential [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") form. - ```python - from qiskit import QuantumRegister, ClassicalRegister, QuantumCircuit - qc = QuantumCircuit(1, 1) - qc.h(0) - qc.measure(0, 0) - qc.draw(output='mpl', style={'backgroundcolor': '#EEEEEE'}) - ``` + * **cargs** – Legacy argument for clbits to attach the bare [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") to. Ignored if the first argument is in the preferential [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") form. - ![../\_images/qiskit-circuit-QuantumCircuit-5.png](/images/api/qiskit/qiskit-circuit-QuantumCircuit-5.png) + **Returns** + + a handle to the instruction that was just added. + + **Return type** + + [CircuitInstruction](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") - ### ecr + In other cases, you may want to join two circuits together, applying the instructions from one circuit onto specified qubits and clbits on another circuit. This “inlining” operation is called [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") in Qiskit. [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") is, in general, more powerful than a [`to_instruction()`](#qiskit.circuit.QuantumCircuit.to_instruction "qiskit.circuit.QuantumCircuit.to_instruction")-plus-[`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") combination for joining two circuits, because it can also link typed classical data together, and allows for circuit control-flow operations to be joined onto another circuit. - - Apply [`ECRGate`](qiskit.circuit.library.ECRGate "qiskit.circuit.library.ECRGate"). + The downsides to [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") are that it is a more complex operation that can involve more rewriting of the operand, and that it necessarily must move data from one circuit object to another. If you are building up a circuit for yourself and raw performance is a core goal, consider passing around your base circuit and having different parts of your algorithm write directly to the base circuit, rather than building a temporary layer circuit. - For the full matrix form of this gate, see the underlying gate documentation. + #### compose - **Parameters** + + Apply the instructions from one circuit onto specified qubits and/or clbits on another. - * **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. + + By default, this creates a new circuit object, leaving `self` untouched. For most uses of this function, it is far more efficient to set `inplace=True` and modify the base circuit in-place. + - **Returns** + When dealing with realtime variables ([`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instances), there are two principal strategies for using [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose"): - A handle to the instructions created. + 1. The `other` circuit is treated as entirely additive, including its variables. The variables in `other` must be entirely distinct from those in `self` (use `var_remap` to help with this), and all variables in `other` will be declared anew in the output with matching input/capture/local scoping to how they are in `other`. This is generally what you want if you’re joining two unrelated circuits. + 2. The `other` circuit was created as an exact extension to `self` to be inlined onto it, including acting on the existing variables in their states at the end of `self`. In this case, `other` should be created with all these variables to be inlined declared as “captures”, and then you can use `inline_captures=True` in this method to link them. This is generally what you want if you’re building up a circuit by defining layers on-the-fly, or rebuilding a circuit using layers taken from itself. You might find the `vars_mode="captures"` argument to [`copy_empty_like()`](#qiskit.circuit.QuantumCircuit.copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like") useful to create each layer’s base, in this case. - **Return type** + **Parameters** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - + * **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. - ### find\_bit + * **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Qubit*](circuit#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. - - Find locations in the circuit which can be used to reference a given [`Bit`](qiskit.circuit.Bit "qiskit.circuit.Bit"). + * **clbits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Clbit*](circuit#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. - **Parameters** + * **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. - **bit** ([*Bit*](qiskit.circuit.Bit "qiskit.circuit.Bit")) – The bit to locate. + * **copy** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True` (the default), then the input is treated as shared, and any contained instructions will be copied, if they might need to be mutated in the future. You can set this to `False` if the input should be considered owned by the base circuit, in order to avoid unnecessary copies; in this case, it is not valid to use `other` afterwards, and some instructions may have been mutated in place. - **Returns** + * **var\_remap** (*Mapping*) – - **A 2-tuple. The first element (`index`)** + mapping to use to rewrite [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes in `other` as they are inlined into `self`. This can be used to avoid naming conflicts. - 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). + Both keys and values can be given as strings or direct [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instances. If a key is a string, it matches any [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") with the same name. If a value is a string, whenever a new key matches a it, a new [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") is created with the correct type. If a value is a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var"), its `type` must exactly match that of the variable it is replacing. - **Return type** + * **inline\_captures** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – - 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)"))]) + if `True`, then all “captured” [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes in the `other` [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") are assumed to refer to variables already declared in `self` (as any input/capture/local type), and the uses in `other` will apply to the existing variables. If you want to build up a layer for an existing circuit to use with [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose"), you might find the `vars_mode="captures"` argument to [`copy_empty_like()`](#qiskit.circuit.QuantumCircuit.copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like") useful. Any remapping in `vars_remap` occurs before evaluating this variable inlining. - **Notes** + If this is `False` (the default), then all variables in `other` will be required to be distinct from those in `self`, and new declarations will be made for them. - 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"). + * **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. Rather than using this option, it is almost always better to manually control this yourself by using [`to_instruction()`](#qiskit.circuit.QuantumCircuit.to_instruction "qiskit.circuit.QuantumCircuit.to_instruction") or [`to_gate()`](#qiskit.circuit.QuantumCircuit.to_gate "qiskit.circuit.QuantumCircuit.to_gate"), and then call [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append"). - **Raises** + **Returns** - * [**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. + the composed circuit (returns None if inplace==True). **Return type** - *BitLocations* - + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ### for\_loop + **Raises** - - Create a `for` loop on this circuit. + * [**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. - 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. + **Examples** - For example: + ```python + >>> lhs.compose(rhs, qubits=[3, 2], inplace=True) + ``` ```python - from qiskit import QuantumCircuit - qc = QuantumCircuit(2, 1) + ┌───┐ ┌─────┐ ┌───┐ + 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 ═══════════════════════ - 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) + lcr_1: 0 ═══════════ lcr_1: 0 ═══════════════════════ ``` + - **Parameters** + If you are trying to join two circuits that will apply to completely disjoint qubits and clbits, [`tensor()`](#qiskit.circuit.QuantumCircuit.tensor "qiskit.circuit.QuantumCircuit.tensor") is a convenient wrapper around manually adding bit objects and calling [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose"). - * **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. + #### tensor - * **loop\_parameter** (*Optional\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*]*) – + + Tensor `self` with `other`. - 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. + Remember that in the little-endian convention the leftmost operation will be at the bottom of the circuit. See also [the docs](/build/circuit-construction) for more information. - 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. + ```python + ┌────────┐ ┌─────┐ ┌─────┐ + q_0: ┤ bottom ├ ⊗ q_0: ┤ top ├ = q_0: ─┤ top ├── + └────────┘ └─────┘ ┌┴─────┴─┐ + q_1: ┤ bottom ├ + └────────┘ + ``` - * **body** (*Optional\[*[*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The loop body to be repeatedly executed. Omit this to use the context-manager mode. + **Parameters** - * **qubits** (*Optional\[Sequence\[QubitSpecifier]]*) – The circuit qubits over which the loop body should be run. Omit this to use the context-manager mode. + * **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. - * **clbits** (*Optional\[Sequence\[ClbitSpecifier]]*) – The circuit clbits over which the loop body should be run. Omit this to use the context-manager mode. + **Return type** - * **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. + [*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") | None - **Returns** + **Examples** - 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. + ```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') + ``` - **Return type** + ![../\_images/qiskit-circuit-QuantumCircuit-3.png](/images/api/qiskit/qiskit-circuit-QuantumCircuit-3.png) - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") or ForLoopContext + **Returns** - **Raises** + The tensored circuit (returns None if inplace==True). - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if an incorrect calling convention is used. - + **Return type** - ### from\_instructions + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + - - Construct a circuit from an iterable of CircuitInstructions. + As some rules of thumb: + + * If you have a single [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation"), [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") or [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"), you should definitely use [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") or [`_append()`](#qiskit.circuit.QuantumCircuit._append "qiskit.circuit.QuantumCircuit._append"). + * If you have a [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") that represents a single atomic instruction for a larger circuit that you want to re-use, you probably want to call [`to_instruction()`](#qiskit.circuit.QuantumCircuit.to_instruction "qiskit.circuit.QuantumCircuit.to_instruction") or [`to_gate()`](#qiskit.circuit.QuantumCircuit.to_gate "qiskit.circuit.QuantumCircuit.to_gate"), and then apply the result of that to the circuit using [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append"). + * If you have a [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") that represents a larger “layer” of another circuit, or contains typed classical variables or control flow, you should use [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") to merge it onto another circuit. + * [`tensor()`](#qiskit.circuit.QuantumCircuit.tensor "qiskit.circuit.QuantumCircuit.tensor") is wanted far more rarely than either [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") or [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose"). Internally, it is mostly a wrapper around [`add_bits()`](#qiskit.circuit.QuantumCircuit.add_bits "qiskit.circuit.QuantumCircuit.add_bits") and [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose"). + + Some potential pitfalls to beware of: + + * Even if you re-use a custom [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") during circuit construction, the transpiler will generally have to “unroll” each invocation of it to its inner decomposition before beginning work on it. This should not prevent you from using the [`to_instruction()`](#qiskit.circuit.QuantumCircuit.to_instruction "qiskit.circuit.QuantumCircuit.to_instruction")-plus-[`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") pattern, as the transpiler will improve in this regard over time. + * [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") will, by default, produce a new circuit for backwards compatibility. This is more expensive, and not usually what you want, so you should set `inplace=True`. + * Both [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") and [`compose()`](#qiskit.circuit.QuantumCircuit.compose "qiskit.circuit.QuantumCircuit.compose") (but not [`_append()`](#qiskit.circuit.QuantumCircuit._append "qiskit.circuit.QuantumCircuit._append")) have a `copy` keyword argument that defaults to `True`. In these cases, the incoming [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") instances will be copied if Qiskit detects that the objects have mutability about them (such as taking gate parameters). If you are sure that you will not re-use the objects again in other places, you should set `copy=False` to prevent this copying, which can be a substantial speed-up for large objects. + + ### Methods to add standard instructions + + The [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") class has helper methods to add many of the Qiskit standard-library instructions and gates onto a circuit. These are generally equivalent to manually constructing an instance of the relevent [`qiskit.circuit.library`](circuit_library#module-qiskit.circuit.library "qiskit.circuit.library") object, then passing that to [`append()`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") with the remaining arguments placed into the `qargs` and `cargs` fields as appropriate. + + The following methods apply special non-unitary [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") operations to the circuit: + + | [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") method | [`qiskit.circuit`](circuit#module-qiskit.circuit "qiskit.circuit") [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") | + | ------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------- | + | [`barrier()`](#qiskit.circuit.QuantumCircuit.barrier "qiskit.circuit.QuantumCircuit.barrier") | [`Barrier`](circuit#qiskit.circuit.Barrier "qiskit.circuit.Barrier") | + | [`delay()`](#qiskit.circuit.QuantumCircuit.delay "qiskit.circuit.QuantumCircuit.delay") | [`Delay`](circuit#qiskit.circuit.Delay "qiskit.circuit.Delay") | + | [`initialize()`](#qiskit.circuit.QuantumCircuit.initialize "qiskit.circuit.QuantumCircuit.initialize") | [`Initialize`](qiskit.circuit.library.Initialize "qiskit.circuit.library.Initialize") | + | [`measure()`](#qiskit.circuit.QuantumCircuit.measure "qiskit.circuit.QuantumCircuit.measure") | [`Measure`](circuit#qiskit.circuit.Measure "qiskit.circuit.Measure") | + | [`reset()`](#qiskit.circuit.QuantumCircuit.reset "qiskit.circuit.QuantumCircuit.reset") | [`Reset`](circuit#qiskit.circuit.Reset "qiskit.circuit.Reset") | + | [`store()`](#qiskit.circuit.QuantumCircuit.store "qiskit.circuit.QuantumCircuit.store") | [`Store`](circuit#qiskit.circuit.Store "qiskit.circuit.Store") | + + These methods apply uncontrolled unitary [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") instances to the circuit: + + | [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") method | [`qiskit.circuit.library`](circuit_library#module-qiskit.circuit.library "qiskit.circuit.library") [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") | + | --------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------ | + | [`dcx()`](#qiskit.circuit.QuantumCircuit.dcx "qiskit.circuit.QuantumCircuit.dcx") | [`DCXGate`](qiskit.circuit.library.DCXGate "qiskit.circuit.library.DCXGate") | + | [`ecr()`](#qiskit.circuit.QuantumCircuit.ecr "qiskit.circuit.QuantumCircuit.ecr") | [`ECRGate`](qiskit.circuit.library.ECRGate "qiskit.circuit.library.ECRGate") | + | [`h()`](#qiskit.circuit.QuantumCircuit.h "qiskit.circuit.QuantumCircuit.h") | [`HGate`](qiskit.circuit.library.HGate "qiskit.circuit.library.HGate") | + | [`id()`](#qiskit.circuit.QuantumCircuit.id "qiskit.circuit.QuantumCircuit.id") | [`IGate`](qiskit.circuit.library.IGate "qiskit.circuit.library.IGate") | + | [`iswap()`](#qiskit.circuit.QuantumCircuit.iswap "qiskit.circuit.QuantumCircuit.iswap") | [`iSwapGate`](qiskit.circuit.library.iSwapGate "qiskit.circuit.library.iSwapGate") | + | [`ms()`](#qiskit.circuit.QuantumCircuit.ms "qiskit.circuit.QuantumCircuit.ms") | [`MSGate`](qiskit.circuit.library.MSGate "qiskit.circuit.library.MSGate") | + | [`p()`](#qiskit.circuit.QuantumCircuit.p "qiskit.circuit.QuantumCircuit.p") | [`PhaseGate`](qiskit.circuit.library.PhaseGate "qiskit.circuit.library.PhaseGate") | + | [`pauli()`](#qiskit.circuit.QuantumCircuit.pauli "qiskit.circuit.QuantumCircuit.pauli") | [`PauliGate`](qiskit.circuit.library.PauliGate "qiskit.circuit.library.PauliGate") | + | [`prepare_state()`](#qiskit.circuit.QuantumCircuit.prepare_state "qiskit.circuit.QuantumCircuit.prepare_state") | [`StatePreparation`](qiskit.circuit.library.StatePreparation "qiskit.circuit.library.StatePreparation") | + | [`r()`](#qiskit.circuit.QuantumCircuit.r "qiskit.circuit.QuantumCircuit.r") | [`RGate`](qiskit.circuit.library.RGate "qiskit.circuit.library.RGate") | + | [`rcccx()`](#qiskit.circuit.QuantumCircuit.rcccx "qiskit.circuit.QuantumCircuit.rcccx") | [`RC3XGate`](qiskit.circuit.library.RC3XGate "qiskit.circuit.library.RC3XGate") | + | [`rccx()`](#qiskit.circuit.QuantumCircuit.rccx "qiskit.circuit.QuantumCircuit.rccx") | [`RCCXGate`](qiskit.circuit.library.RCCXGate "qiskit.circuit.library.RCCXGate") | + | [`rv()`](#qiskit.circuit.QuantumCircuit.rv "qiskit.circuit.QuantumCircuit.rv") | [`RVGate`](qiskit.circuit.library.RVGate "qiskit.circuit.library.RVGate") | + | [`rx()`](#qiskit.circuit.QuantumCircuit.rx "qiskit.circuit.QuantumCircuit.rx") | [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate") | + | [`rxx()`](#qiskit.circuit.QuantumCircuit.rxx "qiskit.circuit.QuantumCircuit.rxx") | [`RXXGate`](qiskit.circuit.library.RXXGate "qiskit.circuit.library.RXXGate") | + | [`ry()`](#qiskit.circuit.QuantumCircuit.ry "qiskit.circuit.QuantumCircuit.ry") | [`RYGate`](qiskit.circuit.library.RYGate "qiskit.circuit.library.RYGate") | + | [`ryy()`](#qiskit.circuit.QuantumCircuit.ryy "qiskit.circuit.QuantumCircuit.ryy") | [`RYYGate`](qiskit.circuit.library.RYYGate "qiskit.circuit.library.RYYGate") | + | [`rz()`](#qiskit.circuit.QuantumCircuit.rz "qiskit.circuit.QuantumCircuit.rz") | [`RZGate`](qiskit.circuit.library.RZGate "qiskit.circuit.library.RZGate") | + | [`rzx()`](#qiskit.circuit.QuantumCircuit.rzx "qiskit.circuit.QuantumCircuit.rzx") | [`RZXGate`](qiskit.circuit.library.RZXGate "qiskit.circuit.library.RZXGate") | + | [`rzz()`](#qiskit.circuit.QuantumCircuit.rzz "qiskit.circuit.QuantumCircuit.rzz") | [`RZZGate`](qiskit.circuit.library.RZZGate "qiskit.circuit.library.RZZGate") | + | [`s()`](#qiskit.circuit.QuantumCircuit.s "qiskit.circuit.QuantumCircuit.s") | [`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate") | + | [`sdg()`](#qiskit.circuit.QuantumCircuit.sdg "qiskit.circuit.QuantumCircuit.sdg") | [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate") | + | [`swap()`](#qiskit.circuit.QuantumCircuit.swap "qiskit.circuit.QuantumCircuit.swap") | [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate") | + | [`sx()`](#qiskit.circuit.QuantumCircuit.sx "qiskit.circuit.QuantumCircuit.sx") | [`SXGate`](qiskit.circuit.library.SXGate "qiskit.circuit.library.SXGate") | + | [`sxdg()`](#qiskit.circuit.QuantumCircuit.sxdg "qiskit.circuit.QuantumCircuit.sxdg") | [`SXdgGate`](qiskit.circuit.library.SXdgGate "qiskit.circuit.library.SXdgGate") | + | [`t()`](#qiskit.circuit.QuantumCircuit.t "qiskit.circuit.QuantumCircuit.t") | [`TGate`](qiskit.circuit.library.TGate "qiskit.circuit.library.TGate") | + | [`tdg()`](#qiskit.circuit.QuantumCircuit.tdg "qiskit.circuit.QuantumCircuit.tdg") | [`TdgGate`](qiskit.circuit.library.TdgGate "qiskit.circuit.library.TdgGate") | + | [`u()`](#qiskit.circuit.QuantumCircuit.u "qiskit.circuit.QuantumCircuit.u") | [`UGate`](qiskit.circuit.library.UGate "qiskit.circuit.library.UGate") | + | [`unitary()`](#qiskit.circuit.QuantumCircuit.unitary "qiskit.circuit.QuantumCircuit.unitary") | [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate") | + | [`x()`](#qiskit.circuit.QuantumCircuit.x "qiskit.circuit.QuantumCircuit.x") | [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate") | + | [`y()`](#qiskit.circuit.QuantumCircuit.y "qiskit.circuit.QuantumCircuit.y") | [`YGate`](qiskit.circuit.library.YGate "qiskit.circuit.library.YGate") | + | [`z()`](#qiskit.circuit.QuantumCircuit.z "qiskit.circuit.QuantumCircuit.z") | [`ZGate`](qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate") | + + The following methods apply [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") instances that are also controlled gates, so are direct subclasses of [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate"): + + | [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") method | [`qiskit.circuit.library`](circuit_library#module-qiskit.circuit.library "qiskit.circuit.library") [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") | + | ----------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | + | [`ccx()`](#qiskit.circuit.QuantumCircuit.ccx "qiskit.circuit.QuantumCircuit.ccx") | [`CCXGate`](qiskit.circuit.library.CCXGate "qiskit.circuit.library.CCXGate") | + | [`ccz()`](#qiskit.circuit.QuantumCircuit.ccz "qiskit.circuit.QuantumCircuit.ccz") | [`CCZGate`](qiskit.circuit.library.CCZGate "qiskit.circuit.library.CCZGate") | + | [`ch()`](#qiskit.circuit.QuantumCircuit.ch "qiskit.circuit.QuantumCircuit.ch") | [`CHGate`](qiskit.circuit.library.CHGate "qiskit.circuit.library.CHGate") | + | [`cp()`](#qiskit.circuit.QuantumCircuit.cp "qiskit.circuit.QuantumCircuit.cp") | [`CPhaseGate`](qiskit.circuit.library.CPhaseGate "qiskit.circuit.library.CPhaseGate") | + | [`crx()`](#qiskit.circuit.QuantumCircuit.crx "qiskit.circuit.QuantumCircuit.crx") | [`CRXGate`](qiskit.circuit.library.CRXGate "qiskit.circuit.library.CRXGate") | + | [`cry()`](#qiskit.circuit.QuantumCircuit.cry "qiskit.circuit.QuantumCircuit.cry") | [`CRYGate`](qiskit.circuit.library.CRYGate "qiskit.circuit.library.CRYGate") | + | [`crz()`](#qiskit.circuit.QuantumCircuit.crz "qiskit.circuit.QuantumCircuit.crz") | [`CRZGate`](qiskit.circuit.library.CRZGate "qiskit.circuit.library.CRZGate") | + | [`cs()`](#qiskit.circuit.QuantumCircuit.cs "qiskit.circuit.QuantumCircuit.cs") | [`CSGate`](qiskit.circuit.library.CSGate "qiskit.circuit.library.CSGate") | + | [`csdg()`](#qiskit.circuit.QuantumCircuit.csdg "qiskit.circuit.QuantumCircuit.csdg") | [`CSdgGate`](qiskit.circuit.library.CSdgGate "qiskit.circuit.library.CSdgGate") | + | [`cswap()`](#qiskit.circuit.QuantumCircuit.cswap "qiskit.circuit.QuantumCircuit.cswap") | [`CSwapGate`](qiskit.circuit.library.CSwapGate "qiskit.circuit.library.CSwapGate") | + | [`csx()`](#qiskit.circuit.QuantumCircuit.csx "qiskit.circuit.QuantumCircuit.csx") | [`CSXGate`](qiskit.circuit.library.CSXGate "qiskit.circuit.library.CSXGate") | + | [`cu()`](#qiskit.circuit.QuantumCircuit.cu "qiskit.circuit.QuantumCircuit.cu") | [`CUGate`](qiskit.circuit.library.CUGate "qiskit.circuit.library.CUGate") | + | [`cx()`](#qiskit.circuit.QuantumCircuit.cx "qiskit.circuit.QuantumCircuit.cx") | [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate") | + | [`cy()`](#qiskit.circuit.QuantumCircuit.cy "qiskit.circuit.QuantumCircuit.cy") | [`CYGate`](qiskit.circuit.library.CYGate "qiskit.circuit.library.CYGate") | + | [`cz()`](#qiskit.circuit.QuantumCircuit.cz "qiskit.circuit.QuantumCircuit.cz") | [`CZGate`](qiskit.circuit.library.CZGate "qiskit.circuit.library.CZGate") | + + Finally, these methods apply particular generalized multiply controlled gates to the circuit, often with eager syntheses. They are listed in terms of the *base* gate they are controlling, since their exact output is often a synthesised version of a gate. + + | [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") method | Base [`qiskit.circuit.library`](circuit_library#module-qiskit.circuit.library "qiskit.circuit.library") [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") | + | ----------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------- | + | [`mcp()`](#qiskit.circuit.QuantumCircuit.mcp "qiskit.circuit.QuantumCircuit.mcp") | [`PhaseGate`](qiskit.circuit.library.PhaseGate "qiskit.circuit.library.PhaseGate") | + | [`mcrx()`](#qiskit.circuit.QuantumCircuit.mcrx "qiskit.circuit.QuantumCircuit.mcrx") | [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate") | + | [`mcry()`](#qiskit.circuit.QuantumCircuit.mcry "qiskit.circuit.QuantumCircuit.mcry") | [`RYGate`](qiskit.circuit.library.RYGate "qiskit.circuit.library.RYGate") | + | [`mcrz()`](#qiskit.circuit.QuantumCircuit.mcrz "qiskit.circuit.QuantumCircuit.mcrz") | [`RZGate`](qiskit.circuit.library.RZGate "qiskit.circuit.library.RZGate") | + | [`mcx()`](#qiskit.circuit.QuantumCircuit.mcx "qiskit.circuit.QuantumCircuit.mcx") | [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate") | + + The rest of this section is the API listing of all the individual methods; the tables above are summaries whose links will jump you to the correct place. + + #### barrier + + + Apply `Barrier`. If `qargs` is empty, applies to all qubits in the circuit. **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. + * **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** - The quantum circuit. + handle to the added instructions. **Return type** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + [qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### from\_qasm\_file + #### ccx - - Read an OpenQASM 2.0 program from a file and convert to an instance of [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + + Apply [`CCXGate`](qiskit.circuit.library.CCXGate "qiskit.circuit.library.CCXGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **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 + * **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** - The QuantumCircuit object for the input OpenQASM 2. + A handle to the instructions created. **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. - + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### from\_qasm\_str + #### ccz - - Convert a string containing an OpenQASM 2.0 program to a [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + + Apply [`CCZGate`](qiskit.circuit.library.CCZGate "qiskit.circuit.library.CCZGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **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. + * **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** - The QuantumCircuit object for the input OpenQASM 2 + A handle to the instructions created. **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. - + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### get\_instructions + #### ch - - Get instructions matching name. + + Apply [`CHGate`](qiskit.circuit.library.CHGate "qiskit.circuit.library.CHGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of instruction to. + * **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** - list of (instruction, qargs, cargs). + A handle to the instructions created. **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)")) + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### get\_parameter + #### cp - - Retrieve a compile-time parameter that is accessible in this circuit scope by name. + + Apply [`CPhaseGate`](qiskit.circuit.library.CPhaseGate "qiskit.circuit.library.CPhaseGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - * **name** – the name of the parameter to retrieve. - * **default** – if given, this value will be returned if the parameter is not present. If it is not given, a [`KeyError`](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") is raised instead. + * **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** - The corresponding parameter. + A handle to the instructions created. - **Raises** + **Return type** - [**KeyError**](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") – if no default is given, but the parameter does not exist in the circuit. + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + - **Examples** + #### crx - Retrieve a parameter by name from a circuit: + + Apply [`CRXGate`](qiskit.circuit.library.CRXGate "qiskit.circuit.library.CRXGate"). - ```python - from qiskit.circuit import QuantumCircuit, Parameter + For the full matrix form of this gate, see the underlying gate documentation. - my_param = Parameter("my_param") + **Parameters** - # Create a parametrised circuit. - qc = QuantumCircuit(1) - qc.rx(my_param, 0) + * **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. - # We can use 'my_param' as a parameter, but let's say we've lost the Python object - # and need to retrieve it. - my_param_again = qc.get_parameter("my_param") + **Returns** - assert my_param is my_param_again - ``` + A handle to the instructions created. - Get a variable from a circuit by name, returning some default if it is not present: + **Return type** - ```python - assert qc.get_parameter("my_param", None) is my_param - assert qc.get_parameter("unknown_param", None) is None - ``` + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### h + #### cry - - Apply [`HGate`](qiskit.circuit.library.HGate "qiskit.circuit.library.HGate"). + + Apply [`CRYGate`](qiskit.circuit.library.CRYGate "qiskit.circuit.library.CRYGate"). 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. + * **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** @@ -1449,67 +1542,69 @@ python_api_name: qiskit.circuit.QuantumCircuit **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### has\_calibration\_for - - - 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. - + #### crz - ### has\_parameter + + Apply [`CRZGate`](qiskit.circuit.library.CRZGate "qiskit.circuit.library.CRZGate"). - - Check whether a parameter object exists in this circuit. + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - **name\_or\_param** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")) – the parameter, or name of a parameter to check. If this is a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") node, the parameter must be exactly the given one for this function to return `True`. + * **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** - whether a matching parameter is assignable in this circuit. + A handle to the instructions created. **Return type** - [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") - - - **[`QuantumCircuit.get_parameter()`](#qiskit.circuit.QuantumCircuit.get_parameter "qiskit.circuit.QuantumCircuit.get_parameter")** - - Retrieve the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instance from this circuit by name. - + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### has\_register + #### cs - - Test if this circuit has the register r. + + Apply [`CSGate`](qiskit.circuit.library.CSGate "qiskit.circuit.library.CSGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - **register** ([*Register*](qiskit.circuit.Register "qiskit.circuit.Register")) – a quantum or classical register. + * **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** - True if the register is contained in this circuit. + A handle to the instructions created. **Return type** - [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### id + #### csdg - - Apply [`IGate`](qiskit.circuit.library.IGate "qiskit.circuit.library.IGate"). + + Apply [`CSdgGate`](qiskit.circuit.library.CSdgGate "qiskit.circuit.library.CSdgGate"). 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. + * **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** @@ -1517,253 +1612,142 @@ python_api_name: qiskit.circuit.QuantumCircuit **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### if\_else - - - Apply [`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp"). + #### cswap - - 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: + + Apply [`CSwapGate`](qiskit.circuit.library.CSwapGate "qiskit.circuit.library.CSwapGate"). - ```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) - ``` - + For the full matrix form of this gate, see the underlying gate documentation. **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. + * **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 instruction created. + A handle to the instructions created. **Return type** [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### if\_test + #### csx - - 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) + + Apply [`CSXGate`](qiskit.circuit.library.CSXGate "qiskit.circuit.library.CSXGate"). - with qc.if_test((bits[3], 0)) as else_: - qc.x(2) - with else_: - qc.h(2) - qc.z(2) - ``` + For the full matrix form of this gate, see the underlying gate documentation. **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. + * **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** - 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. + A handle to the instructions created. **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. + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### initialize + #### cu - - Initialize qubits in a specific state. + + Apply [`CUGate`](qiskit.circuit.library.CUGate "qiskit.circuit.library.CUGate"). - 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. + For the full matrix form of this gate, see the underlying gate documentation. **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$. - - * **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. + * **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. - **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) ├ - └──────────────────────────────┘ - ``` + **Return type** - 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"). + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + - ```python - import numpy as np - from qiskit import QuantumCircuit + #### cx - circuit = QuantumCircuit(2) - circuit.initialize('01', circuit.qubits) - circuit.draw() - ``` + + Apply [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate"). - output: + For the full matrix form of this gate, see the underlying gate documentation. - ```python - ┌──────────────────┐ - q_0: ┤0 ├ - │ Initialize(0,1) │ - q_1: ┤1 ├ - └──────────────────┘ - ``` + **Parameters** - Initialize two qubits from an array of complex amplitudes. + * **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. - ```python - import numpy as np - from qiskit import QuantumCircuit + **Returns** - circuit = QuantumCircuit(2) - circuit.initialize([0, 1/np.sqrt(2), -1.j/np.sqrt(2), 0], circuit.qubits) - circuit.draw() - ``` + A handle to the instructions created. - output: + **Return type** - ```python - ┌────────────────────────────────────┐ - q_0: ┤0 ├ - │ Initialize(0,0.70711,-0.70711j,0) │ - q_1: ┤1 ├ - └────────────────────────────────────┘ - ``` + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### inverse + #### cy - - Invert (take adjoint of) this circuit. + + Apply [`CYGate`](qiskit.circuit.library.CYGate "qiskit.circuit.library.CYGate"). - This is done by recursively inverting all gates. + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the inverse gate can be implemented as an annotated gate. + * **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** - the inverted circuit + A handle to the instructions created. **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) ├───── - └───────────┘ - ``` + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### iswap + #### cz - - Apply [`iSwapGate`](qiskit.circuit.library.iSwapGate "qiskit.circuit.library.iSwapGate"). + + Apply [`CZGate`](qiskit.circuit.library.CZGate "qiskit.circuit.library.CZGate"). 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. + * **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** @@ -1771,21 +1755,20 @@ python_api_name: qiskit.circuit.QuantumCircuit **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### mcp + #### dcx - - Apply [`MCPhaseGate`](qiskit.circuit.library.MCPhaseGate "qiskit.circuit.library.MCPhaseGate"). + + Apply [`DCXGate`](qiskit.circuit.library.DCXGate "qiskit.circuit.library.DCXGate"). 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. + * **qubit1** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -1796,36 +1779,254 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### mcrx + #### delay - - Apply Multiple-Controlled X rotation gate + + Apply [`Delay`](circuit#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** - * **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 + * **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. + + + #### ecr + + + 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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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") + + + #### h + + + 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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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 + + + 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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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") + + + #### initialize + + + 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** ([*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$. + + * **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 ├ + └────────────────────────────────────┘ + ``` + + + #### iswap + + + 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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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 + + + 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** (*ParameterValueType*) – The angle of the rotation. + * **control\_qubits** (*Sequence\[QubitSpecifier]*) – The qubits used as the controls. + * **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") + + + #### mcrx + + + 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*](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*)*) – The list of control qubits + * **q\_target** ([*Qubit*](circuit#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 - + 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. + * **q\_controls** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*)*) – The list of control qubits + * **q\_target** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")) – The target qubit + * **q\_ancillae** ([*QuantumRegister*](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*(*[*QuantumRegister*](circuit#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 @@ -1834,17 +2035,17 @@ python_api_name: qiskit.circuit.QuantumCircuit [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – parameter errors - ### mcrz + #### mcrz - + 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 + * **q\_controls** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*)*) – The list of control qubits + * **q\_target** ([*Qubit*](circuit#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** @@ -1852,9 +2053,9 @@ python_api_name: qiskit.circuit.QuantumCircuit [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – parameter errors - ### mcx + #### mcx - + 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: @@ -1872,6 +2073,7 @@ python_api_name: qiskit.circuit.QuantumCircuit * **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. + * **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** @@ -1887,17 +2089,17 @@ python_api_name: qiskit.circuit.QuantumCircuit [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### measure + #### measure - + 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. + * **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Clbit "qiskit.circuit.classicalregister.Clbit") *|*[*ClassicalRegister*](circuit#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*](circuit#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** @@ -1944,7 +2146,7 @@ python_api_name: qiskit.circuit.QuantumCircuit 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. + Instead of lists, you can use [`QuantumRegister`](circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") and [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") under the same logic. ```python from qiskit import QuantumCircuit, QuantumRegister, ClassicalRegister @@ -1963,64 +2165,57 @@ python_api_name: qiskit.circuit.QuantumCircuit ``` - ### measure\_active + #### ms - - Adds measurement to all non-idle qubits. Creates a new ClassicalRegister with a size equal to the number of non-idle qubits being measured. + + Apply [`MSGate`](qiskit.circuit.library.MSGate "qiskit.circuit.library.MSGate"). - Returns a new circuit with measurements if inplace=False. + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – All measurements inplace or return new circuit. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - Returns circuit with measurements when inplace = False. + A handle to the instructions created. **Return type** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### measure\_all + #### p - - 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`. + + Apply [`PhaseGate`](qiskit.circuit.library.PhaseGate "qiskit.circuit.library.PhaseGate"). - Returns a new circuit with measurements if `inplace=False`. + For the full matrix form of this gate, see the underlying gate documentation. **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. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - Returns circuit with measurements when `inplace=False`. + A handle to the instructions created. **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. + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### ms + #### pauli - - Apply [`MSGate`](qiskit.circuit.library.MSGate "qiskit.circuit.library.MSGate"). - - For the full matrix form of this gate, see the underlying gate documentation. + + Apply [`PauliGate`](qiskit.circuit.library.PauliGate "qiskit.circuit.library.PauliGate"). **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. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -2031,157 +2226,38 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### num\_connected\_components + #### prepare\_state - - How many non-entangled subcircuits can the circuit be factored to. + + Prepare qubits in a specific state. + + This class implements a state preparing unitary. Unlike [`initialize()`](#qiskit.circuit.QuantumCircuit.initialize "qiskit.circuit.QuantumCircuit.initialize") it does not reset the qubits first. **Parameters** - **unitary\_only** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Compute only unitary part of graph. + * **state** ([*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)")) – - **Returns** + The state to initialize to, can be either of the following. - Number of connected components in circuit. + * 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$. - **Return type** + * **qubits** (*Sequence\[QubitSpecifier] | None*) – Qubits to initialize. If `None` the initialization is applied to all qubits in the circuit. - [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") - + * **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – An optional label for the gate - ### num\_nonlocal\_gates + * **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. - - Return number of non-local gates (i.e. involving 2+ qubits). + **Returns** - Conditional nonlocal gates are also included. + A handle to the instruction that was just initialized **Return type** - [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") - + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### 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 - - - 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 - - - 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 - - - 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 - - - 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 qubits in a specific state. - - This class implements a state preparing unitary. Unlike [`initialize()`](#qiskit.circuit.QuantumCircuit.initialize "qiskit.circuit.QuantumCircuit.initialize") it does not reset the qubits first. - - **Parameters** - - * **state** ([*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$. - - * **qubits** (*Sequence\[QubitSpecifier] | None*) – Qubits to initialize. If `None` the initialization is applied to all qubits in the circuit. - - * **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. - - **Returns** - - A handle to the instruction that was just initialized - - **Return type** - - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - - **Examples** + **Examples** Prepare a qubit in the state $(|0\rangle - |1\rangle) / \sqrt{2}$. @@ -2245,104 +2321,150 @@ python_api_name: qiskit.circuit.QuantumCircuit ``` - ### qbit\_argument\_conversion + #### r - - Converts several qubit representations (such as indexes, range, etc.) into a list of qubits. + + Apply [`RGate`](qiskit.circuit.library.RGate "qiskit.circuit.library.RGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - **qubit\_representation** (*Object*) – representation to expand + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - the resolved instances of the qubits. + A handle to the instructions created. **Return type** - List([Qubit](qiskit.circuit.Qubit "qiskit.circuit.Qubit")) + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### qubit\_duration + #### rcccx - - 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`. + + Apply [`RC3XGate`](qiskit.circuit.library.RC3XGate "qiskit.circuit.library.RC3XGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **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. + * **control\_qubit1** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - Return the duration between the first start and last stop time of non-delay instructions + A handle to the instructions created. **Return type** - [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### qubit\_start\_time + #### rccx - - Return the start time of the first instruction, excluding delays, over the supplied qubits. Its time unit is `self.unit`. + + Apply [`RCCXGate`](qiskit.circuit.library.RCCXGate "qiskit.circuit.library.RCCXGate"). - Return 0 if there are no instructions over qubits + For the full matrix form of this gate, see the underlying gate documentation. **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*) – + * **control\_qubit1** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - Return the start time of the first instruction, excluding delays, over the qubits + A handle to the instructions created. - **Raises** + **Return type** - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `self` is a not-yet scheduled circuit. + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + + + #### reset + + + Reset the quantum bit(s) to their default state. + + **Parameters** + + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + [qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### qubit\_stop\_time + #### rv - - Return the stop time of the last instruction, excluding delays, over the supplied qubits. Its time unit is `self.unit`. + + Apply [`RVGate`](qiskit.circuit.library.RVGate "qiskit.circuit.library.RVGate"). - Return 0 if there are no instructions over qubits + 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** - * **\*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*) – + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - Return the stop time of the last instruction, excluding delays, over the qubits + A handle to the instructions created. - **Raises** + **Return type** - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `self` is a not-yet scheduled circuit. + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + + + #### rx + + + 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** - [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### r + #### rxx - - Apply [`RGate`](qiskit.circuit.library.RGate "qiskit.circuit.library.RGate"). + + 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. - * **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. + * **qubit1** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -2353,19 +2475,18 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### rcccx + #### ry - - Apply [`RC3XGate`](qiskit.circuit.library.RC3XGate "qiskit.circuit.library.RC3XGate"). + + Apply [`RYGate`](qiskit.circuit.library.RYGate "qiskit.circuit.library.RYGate"). 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. + * **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** @@ -2373,21 +2494,21 @@ python_api_name: qiskit.circuit.QuantumCircuit **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### rccx + #### ryy - - Apply [`RCCXGate`](qiskit.circuit.library.RCCXGate "qiskit.circuit.library.RCCXGate"). + + Apply [`RYYGate`](qiskit.circuit.library.RYYGate "qiskit.circuit.library.RYYGate"). 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. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -2398,167 +2519,149 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### remove\_final\_measurements + #### rz - - 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. + + Apply [`RZGate`](qiskit.circuit.library.RZGate "qiskit.circuit.library.RZGate"). - Measurements and barriers are considered final if they are followed by no other operations (aside from other measurements or barriers.) + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – All measurements removed inplace or return new circuit. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - Returns the resulting circuit when `inplace=False`, else None. + A handle to the instructions created. **Return type** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### repeat + #### rzx - - Repeat this circuit `reps` times. + + Apply [`RZXGate`](qiskit.circuit.library.RZXGate "qiskit.circuit.library.RZXGate"). + + For the full matrix form of this gate, see the underlying gate documentation. **Parameters** - **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – How often this circuit should be repeated. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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 circuit containing `reps` repetitions of this circuit. + A handle to the instructions created. **Return type** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### reset + #### rzz - - Reset the quantum bit(s) to their default state. + + Apply [`RZZGate`](qiskit.circuit.library.RZZGate "qiskit.circuit.library.RZZGate"). + + 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)")*]*) – qubit(s) to reset. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - handle to the added instruction. + A handle to the instructions created. **Return type** - [qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### reverse\_bits + #### s - - Return a circuit with the opposite order of wires. + + Apply [`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate"). - 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. + For the full matrix form of this gate, see the underlying gate documentation. - This method is useful for converting a circuit written in little-endian convention to the big-endian equivalent, and vice versa. + **Parameters** + + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** - the circuit with reversed bit order. + A handle to the instructions created. **Return type** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + - **Examples** + #### sdg - input: + + Apply [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate"). - ```python - ┌───┐ - a_0: ┤ H ├──■───────────────── - └───┘┌─┴─┐ - a_1: ─────┤ X ├──■──────────── - └───┘┌─┴─┐ - a_2: ──────────┤ X ├──■─────── - └───┘┌─┴─┐ - b_0: ───────────────┤ X ├──■── - └───┘┌─┴─┐ - b_1: ────────────────────┤ X ├ - └───┘ - ``` + For the full matrix form of this gate, see the underlying gate documentation. - output: + **Parameters** - ```python - ┌───┐ - b_0: ────────────────────┤ X ├ - ┌───┐└─┬─┘ - b_1: ───────────────┤ X ├──■── - ┌───┐└─┬─┘ - a_0: ──────────┤ X ├──■─────── - ┌───┐└─┬─┘ - a_1: ─────┤ X ├──■──────────── - ┌───┐└─┬─┘ - a_2: ┤ H ├──■───────────────── - └───┘ - ``` + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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") - ### reverse\_ops + #### store - - Reverse the circuit by reversing the order of instructions. + + Store the result of the given real-time classical expression `rvalue` in the memory location defined by `lvalue`. - This is done by recursively reversing all instructions. It does not invert (adjoint) any gate. + Typically `lvalue` will be a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node and `rvalue` will be some [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") to write into it, but anything that [`expr.lift()`](circuit_classical#qiskit.circuit.classical.expr.lift "qiskit.circuit.classical.expr.lift") can raise to an [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") is permissible in both places, and it will be called on them. - **Returns** + **Parameters** - the reversed circuit. + * **lvalue** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – a valid specifier for a memory location in the circuit. This will typically be a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node, but you can also write to [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") or [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") memory locations if your hardware supports it. The memory location must already be present in the circuit. + * **rvalue** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – a real-time classical expression whose result should be written into the given memory location. **Return type** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - - **Examples** + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - input: + + **[`Store`](circuit#qiskit.circuit.Store "qiskit.circuit.Store")** - ```python - ┌───┐ - q_0: ┤ H ├─────■────── - └───┘┌────┴─────┐ - q_1: ─────┤ RX(1.57) ├ - └──────────┘ - ``` + The backing [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") class that represents this operation. - output: + **[`add_var()`](#qiskit.circuit.QuantumCircuit.add_var "qiskit.circuit.QuantumCircuit.add_var")** - ```python - ┌───┐ - q_0: ─────■──────┤ H ├ - ┌────┴─────┐└───┘ - q_1: ┤ RX(1.57) ├───── - └──────────┘ - ``` + Create a new variable in the circuit that can be written to with this method. + - ### rv + #### swap - - Apply [`RVGate`](qiskit.circuit.library.RVGate "qiskit.circuit.library.RVGate"). + + Apply [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate"). 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. + * **qubit1** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -2569,18 +2672,16 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### rx + #### sx - - Apply [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"). + + Apply [`SXGate`](qiskit.circuit.library.SXGate "qiskit.circuit.library.SXGate"). 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. + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -2588,21 +2689,19 @@ python_api_name: qiskit.circuit.QuantumCircuit **Return type** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### rxx + #### sxdg - - Apply [`RXXGate`](qiskit.circuit.library.RXXGate "qiskit.circuit.library.RXXGate"). + + Apply [`SXdgGate`](qiskit.circuit.library.SXdgGate "qiskit.circuit.library.SXdgGate"). 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. + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -2613,18 +2712,16 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### ry + #### t - - Apply [`RYGate`](qiskit.circuit.library.RYGate "qiskit.circuit.library.RYGate"). + + Apply [`TGate`](qiskit.circuit.library.TGate "qiskit.circuit.library.TGate"). 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. + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -2632,21 +2729,19 @@ python_api_name: qiskit.circuit.QuantumCircuit **Return type** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### ryy + #### tdg - - Apply [`RYYGate`](qiskit.circuit.library.RYYGate "qiskit.circuit.library.RYYGate"). + + Apply [`TdgGate`](qiskit.circuit.library.TdgGate "qiskit.circuit.library.TdgGate"). 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. + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -2657,17 +2752,19 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### rz + #### u - - Apply [`RZGate`](qiskit.circuit.library.RZGate "qiskit.circuit.library.RZGate"). + + Apply [`UGate`](qiskit.circuit.library.UGate "qiskit.circuit.library.UGate"). 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. + * **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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -2678,40 +2775,51 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### rzx - - - Apply [`RZXGate`](qiskit.circuit.library.RZXGate "qiskit.circuit.library.RZXGate"). + #### unitary - For the full matrix form of this gate, see the underlying gate documentation. + + Apply unitary gate specified by `obj` to `qubits`. **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. + * **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** - A handle to the instructions created. + The quantum circuit. **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [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]) + ``` - ### rzz + #### x - - Apply [`RZZGate`](qiskit.circuit.library.RZZGate "qiskit.circuit.library.RZZGate"). + + Apply [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate"). 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. + * **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** @@ -2719,19 +2827,19 @@ python_api_name: qiskit.circuit.QuantumCircuit **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### s + #### y - - Apply [`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate"). + + 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. + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -2742,16 +2850,16 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### sdg + #### z - - Apply [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate"). + + 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. + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](circuit#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*](circuit#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** @@ -2762,428 +2870,1214 @@ python_api_name: qiskit.circuit.QuantumCircuit [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### size + - - Returns total number of instructions in circuit. + ### Adding control flow to circuits - **Parameters** + + [Control flow in circuits](circuit#circuit-control-flow-repr) - **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. + Discussion of how control-flow operations are represented in the whole [`qiskit.circuit`](circuit#module-qiskit.circuit "qiskit.circuit") context. + + + | [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") method | Control-flow instruction | + | --------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------- | + | [`if_test()`](#qiskit.circuit.QuantumCircuit.if_test "qiskit.circuit.QuantumCircuit.if_test") | [`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp") with only a `True` body. | + | [`if_else()`](#qiskit.circuit.QuantumCircuit.if_else "qiskit.circuit.QuantumCircuit.if_else") | [`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp") with both `True` and `False` bodies. | + | [`while_loop()`](#qiskit.circuit.QuantumCircuit.while_loop "qiskit.circuit.QuantumCircuit.while_loop") | [`WhileLoopOp`](qiskit.circuit.WhileLoopOp "qiskit.circuit.WhileLoopOp"). | + | [`switch()`](#qiskit.circuit.QuantumCircuit.switch "qiskit.circuit.QuantumCircuit.switch") | [`SwitchCaseOp`](qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp"). | + | [`for_loop()`](#qiskit.circuit.QuantumCircuit.for_loop "qiskit.circuit.QuantumCircuit.for_loop") | [`ForLoopOp`](qiskit.circuit.ForLoopOp "qiskit.circuit.ForLoopOp"). | + | [`break_loop()`](#qiskit.circuit.QuantumCircuit.break_loop "qiskit.circuit.QuantumCircuit.break_loop") | [`BreakLoopOp`](qiskit.circuit.BreakLoopOp "qiskit.circuit.BreakLoopOp"). | + | [`continue_loop()`](#qiskit.circuit.QuantumCircuit.continue_loop "qiskit.circuit.QuantumCircuit.continue_loop") | [`ContinueLoopOp`](qiskit.circuit.ContinueLoopOp "qiskit.circuit.ContinueLoopOp"). | + + [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") has corresponding methods for all of the control-flow operations that are supported by Qiskit. These have two forms for calling them. The first is a very straightfowards convenience wrapper that takes in the block bodies of the instructions as [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") arguments, and simply constructs and appends the corresponding [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp"). + + The second form, which we strongly recommend you use for constructing control flow, is called *the builder interface*. Here, the methods take only the real-time discriminant of the operation, and return [context managers](https://docs.python.org/3/library/stdtypes.html#typecontextmanager) that you enter using `with`. You can then use regular [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") methods within those blocks to build up the control-flow bodies, and Qiskit will automatically track which of the data resources are needed for the inner blocks, building the complete [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") as you leave the `with` statement. It is far simpler and less error-prone to build control flow programmatically this way. + + #### 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** - Total number of gate operations. + 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** - [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - ### swap + #### continue\_loop - - Apply [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate"). + + Apply [`ContinueLoopOp`](qiskit.circuit.ContinueLoopOp "qiskit.circuit.ContinueLoopOp"). - For the full matrix form of this gate, see the underlying gate documentation. + + 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. + - **Parameters** + **Returns** - * **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. + A handle to the instruction created. - **Returns** + **Raises** - A handle to the instructions created. + [**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") - ### switch + #### for\_loop - - Create a `switch`/`case` structure on this circuit. + + 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 [`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. + 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. - Example usage: + For example: ```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]) + from qiskit import QuantumCircuit + qc = QuantumCircuit(2, 1) - 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) + 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** - * **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 + * **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. - **Raises** + * **loop\_parameter** (*Optional\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*]*) – - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if an incorrect calling convention is used. - + 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. - ### sx + 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. - - Apply [`SXGate`](qiskit.circuit.library.SXGate "qiskit.circuit.library.SXGate"). + * **body** (*Optional\[*[*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The loop body to be repeatedly executed. Omit this to use the context-manager mode. - For the full matrix form of this gate, see the underlying gate documentation. + * **qubits** (*Optional\[Sequence\[QubitSpecifier]]*) – The circuit qubits over which the loop body should be run. Omit this to use the context-manager mode. - **Parameters** + * **clbits** (*Optional\[Sequence\[ClbitSpecifier]]*) – The circuit clbits over which the loop body should be run. Omit this to use the context-manager mode. - **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. + * **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** - A handle to the instructions created. + 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.InstructionSet") + [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. - ### sxdg + #### if\_else - - Apply [`SXdgGate`](qiskit.circuit.library.SXdgGate "qiskit.circuit.library.SXdgGate"). + + Apply [`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp"). - For the full matrix form of this gate, see the underlying gate documentation. + + 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** - **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. + * **condition** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*ClassicalRegister*](circuit#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*](circuit#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*](circuit#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 in real time at circuit execution, 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 instructions created. + A handle to the instruction created. **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") - ### t + #### if\_test - - Apply [`TGate`](qiskit.circuit.library.TGate "qiskit.circuit.library.TGate"). - - For the full matrix form of this gate, see the underlying gate documentation. + + Create an `if` statement on this circuit. - **Parameters** + 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. - **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. + For example: - **Returns** + ```python + from qiskit.circuit import QuantumCircuit, Qubit, Clbit + bits = [Qubit(), Qubit(), Qubit(), Clbit(), Clbit()] + qc = QuantumCircuit(bits) - A handle to the instructions created. + qc.h(0) + qc.cx(0, 1) + qc.measure(0, 0) + qc.h(0) + qc.cx(0, 1) + qc.measure(0, 1) - **Return type** + with qc.if_test((bits[3], 0)) as else_: + qc.x(2) + with else_: + qc.h(2) + qc.z(2) + ``` - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - + **Parameters** - ### tdg + * **condition** (*Tuple\[Union\[*[*ClassicalRegister*](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")*,* [*Clbit*](circuit#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 in real time during circuit execution, 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. - - Apply [`TdgGate`](qiskit.circuit.library.TdgGate "qiskit.circuit.library.TdgGate"). + **Returns** - For the full matrix form of this gate, see the underlying gate documentation. + 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. - **Parameters** + **Return type** - **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. + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") or IfContext - **Returns** + **Raises** - A handle to the instructions created. + * [**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. - **Return type** + **Returns** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + A handle to the instruction created. - ### tensor + #### switch - - Tensor `self` with `other`. + + Create a `switch`/`case` structure on this circuit. - Remember that in the little-endian convention the leftmost operation will be at the bottom of the circuit. See also [the docs](/build/circuit-construction) for more information. + 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 - ┌────────┐ ┌─────┐ ┌─────┐ - q_0: ┤ bottom ├ ⊗ q_0: ┤ top ├ = q_0: ─┤ top ├── - └────────┘ └─────┘ ┌┴─────┴─┐ - q_1: ┤ bottom ├ - └────────┘ + 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** - * **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. + * **target** (*Union\[*[*ClassicalRegister*](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")*,* [*Clbit*](circuit#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*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – The circuit qubits over which all case bodies execute. Omit in context-manager form. + * **clbits** (*Sequence\[*[*Clbit*](circuit#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** - [*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") | None + [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") or SwitchCaseContext - **Examples** + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if an incorrect calling convention is used. + + + #### while\_loop + + + 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 import QuantumCircuit - top = QuantumCircuit(1) - top.x(0); - bottom = QuantumCircuit(2) - bottom.cry(0.2, 0, 1); - tensored = bottom.tensor(top) - tensored.draw('mpl') + 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) ``` - ![../\_images/qiskit-circuit-QuantumCircuit-6.png](/images/api/qiskit/qiskit-circuit-QuantumCircuit-6.png) + **Parameters** + + * **condition** (*Tuple\[Union\[*[*ClassicalRegister*](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")*,* [*Clbit*](circuit#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`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") or a [`Clbit`](circuit#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*](circuit#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*](circuit#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** - The tensored circuit (returns None if inplace==True). + 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** - [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + [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. - ### to\_gate + ### Converting circuits to single objects + + As discussed in [Methods to add general operations](#circuit-append-compose), you can convert a circuit to either an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") or a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") using two helper methods. - - Create a Gate out of this circuit. + #### to\_instruction + + + Create an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") out of this circuit. + + + **`circuit_to_instruction()`** + + The underlying driver of this method. + **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. + * **parameter\_map** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*, ParameterValueType] | None*) – 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)") *| None*) – Optional gate label. **Returns** - a composite gate encapsulating this circuit (can be decomposed back) + **a composite instruction encapsulating this circuit (can be** + + decomposed back). **Return type** - [Gate](qiskit.circuit.Gate "qiskit.circuit.Gate") + [qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") - ### to\_instruction + #### to\_gate - - Create an Instruction out of this circuit. + + Create a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") out of this circuit. The circuit must act only qubits and contain only unitary operations. + + + **`circuit_to_gate()`** + + The underlying driver of this method. + **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. + * **parameter\_map** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*, ParameterValueType] | None*) – 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)") *| None*) – Optional gate label. **Returns** - a composite instruction encapsulating this circuit (can be decomposed back) + a composite gate encapsulating this circuit (can be decomposed back). **Return type** - [qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + [Gate](qiskit.circuit.Gate "qiskit.circuit.Gate") - ### u + ### Helper mutation methods - - Apply [`UGate`](qiskit.circuit.library.UGate "qiskit.circuit.library.UGate"). + There are two higher-level methods on [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") for appending measurements to the end of a circuit. Note that by default, these also add an extra register. - For the full matrix form of this gate, see the underlying gate documentation. + #### measure\_active + + + 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** - * **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. + **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – All measurements inplace or return new circuit. **Returns** - A handle to the instructions created. + Returns circuit with measurements when inplace = False. **Return type** - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ### unitary + #### measure\_all - - Apply unitary gate specified by `obj` to `qubits`. + + Adds measurement to all qubits. + + By default, adds new classical bits in a [`ClassicalRegister`](circuit#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** - * **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]. + * **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** - The quantum circuit. + Returns circuit with measurements when `inplace=False`. **Return type** [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - **Example** - - Apply a gate specified by a unitary matrix to a quantum circuit + **Raises** - ```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]) - ``` + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `add_bits=False` but there are not enough classical bits. - ### while\_loop + There are two “subtractive” methods on [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") as well. This is not a use-case that [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") is designed for; typically you should just look to use [`copy_empty_like()`](#qiskit.circuit.QuantumCircuit.copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like") in place of [`clear()`](#qiskit.circuit.QuantumCircuit.clear "qiskit.circuit.QuantumCircuit.clear"), and run [`remove_final_measurements()`](#qiskit.circuit.QuantumCircuit.remove_final_measurements "qiskit.circuit.QuantumCircuit.remove_final_measurements") as its transpiler-pass form [`RemoveFinalMeasurements`](qiskit.transpiler.passes.RemoveFinalMeasurements "qiskit.transpiler.passes.RemoveFinalMeasurements"). - - Create a `while` loop on this circuit. + #### clear - 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. + + Clear all instructions in self. - Example usage: + Clearing the circuits will keep the metadata and calibrations. - ```python - from qiskit.circuit import QuantumCircuit, Clbit, Qubit - bits = [Qubit(), Qubit(), Clbit()] - qc = QuantumCircuit(bits) + + **[`copy_empty_like()`](#qiskit.circuit.QuantumCircuit.copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like")** - with qc.while_loop((bits[2], 0)): - qc.h(0) - qc.cx(0, 1) - qc.measure(0, 0) - ``` + A method to produce a new circuit with no instructions and all the same tracking of quantum and classical typed data, but without mutating the original circuit. + + - **Parameters** + #### remove\_final\_measurements - * **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. + + 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. - **Returns** + Measurements and barriers are considered final if they are followed by no other operations (aside from other measurements or barriers.) - 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. + + This method has rather complex behavior, particularly around the removal of newly idle classical bits and registers. It is much more efficient to avoid adding unnecessary classical data in the first place, rather than trying to remove it later. + - **Return type** + + **[`RemoveFinalMeasurements`](qiskit.transpiler.passes.RemoveFinalMeasurements "qiskit.transpiler.passes.RemoveFinalMeasurements")** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") or WhileLoopContext + A transpiler pass that removes final measurements and barriers. This does not remove the classical data. If this is your goal, you can call that with: - **Raises** + ```python + from qiskit.circuit import QuantumCircuit + from qiskit.transpiler.passes import RemoveFinalMeasurements - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if an incorrect calling convention is used. - + qc = QuantumCircuit(2, 2) + qc.h(0) + qc.cx(0, 1) + qc.barrier() + qc.measure([0, 1], [0, 1]) - ### width + pass_ = RemoveFinalMeasurements() + just_bell = pass_(qc) + ``` + - - Return number of qubits plus clbits in circuit. + **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** - Width of circuit. + Returns the resulting circuit when `inplace=False`, else None. **Return type** - [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") - ### x + - - Apply [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate"). + ### Manual calibration of instructions - For the full matrix form of this gate, see the underlying gate documentation. + [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") can store [`calibrations`](#qiskit.circuit.QuantumCircuit.calibrations "qiskit.circuit.QuantumCircuit.calibrations") of instructions that define the pulses used to run them on one particular hardware backend. You can - **Parameters** + #### add\_calibration - * **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. + + Register a low-level, custom pulse definition for the given gate. - **Returns** + **Parameters** - A handle to the instructions created. + * **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. - **Return type** + **Raises** - [InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + [**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. - ### y + #### has\_calibration\_for - - Apply [`YGate`](qiskit.circuit.library.YGate "qiskit.circuit.library.YGate"). + + 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. + - For the full matrix form of this gate, see the underlying gate documentation. + ## Circuit properties - **Parameters** + ### Simple circuit metrics - **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. + 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. - **Returns** + Consider the following circuit: - A handle to the instructions created. + ```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') + ``` - **Return type** + ![../\_images/qiskit-circuit-QuantumCircuit-4.png](/images/api/qiskit/qiskit-circuit-QuantumCircuit-4.png) - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") - + 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()`](#qiskit.circuit.QuantumCircuit.width "qiskit.circuit.QuantumCircuit.width") of the circuit: - ### z + ```python + assert qc.width() == 12 + ``` - - Apply [`ZGate`](qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate"). + We can also just get the number of qubits directly using [`num_qubits`](#qiskit.circuit.QuantumCircuit.num_qubits "qiskit.circuit.QuantumCircuit.num_qubits"): - For the full matrix form of this gate, see the underlying gate documentation. + ```python + assert qc.num_qubits == 12 + ``` - **Parameters** + + 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. + - **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. + It is also straightforward to get the number and type of the gates in a circuit using [`count_ops()`](#qiskit.circuit.QuantumCircuit.count_ops "qiskit.circuit.QuantumCircuit.count_ops"): - **Returns** + ```python + qc.count_ops() + ``` - A handle to the instructions created. + ```python + OrderedDict([('cx', 8), ('h', 5), ('x', 3), ('swap', 3)]) + ``` - **Return type** + We can also get just the raw count of operations by computing the circuits [`size()`](#qiskit.circuit.QuantumCircuit.size "qiskit.circuit.QuantumCircuit.size"): - [*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + ```python + assert qc.size() == 19 + ``` + + A particularly important circuit property is known as the circuit [`depth()`](#qiskit.circuit.QuantumCircuit.depth "qiskit.circuit.QuantumCircuit.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/depth.gif) + + We can verify our graphical result using [`QuantumCircuit.depth()`](#qiskit.circuit.QuantumCircuit.depth "qiskit.circuit.QuantumCircuit.depth"): + + ```python + assert qc.depth() == 9 + ``` + + #### 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 + + + #### depth + + + Return circuit depth (i.e., length of critical path). + + **Parameters** + + **filter\_function** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*CircuitInstruction*](qiskit.circuit.CircuitInstruction "qiskit._accelerate.circuit.CircuitInstruction")*],* [*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*]*) – A function to decide which instructions count to increase depth. Should take as a single positional input a [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction"). Instructions for which the function returns `False` are ignored in the computation of the circuit depth. By default filters out “directives”, such as [`Barrier`](circuit#qiskit.circuit.Barrier "qiskit.circuit.Barrier"). + + **Returns** + + Depth of circuit. + + **Return type** + + [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + **Examples** + + Simple calculation of total circuit depth: + + ```python + from qiskit.circuit import QuantumCircuit + qc = QuantumCircuit(4) + qc.h(0) + qc.cx(0, 1) + qc.h(2) + qc.cx(2, 3) + assert qc.depth() == 2 + ``` + + Modifying the previous example to only calculate the depth of multi-qubit gates: + + ```python + assert qc.depth(lambda instr: len(instr.qubits) > 1) == 1 + ``` + + + #### get\_instructions + + + 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)")) + + + #### num\_connected\_components + + + 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 + + + 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 + + + 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 + + + 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)") + + + #### size + + + 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)") + + + #### 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)") + + + ### Accessing scheduling information + + If a [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") has been scheduled as part of a transpilation pipeline, the timing information for individual qubits can be accessed. The whole-circuit timing information is available through the [`duration`](#qiskit.circuit.QuantumCircuit.duration "qiskit.circuit.QuantumCircuit.duration"), [`unit`](#qiskit.circuit.QuantumCircuit.unit "qiskit.circuit.QuantumCircuit.unit") and [`op_start_times`](#qiskit.circuit.QuantumCircuit.op_start_times "qiskit.circuit.QuantumCircuit.op_start_times") attributes. + + #### qubit\_duration + + + 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*](circuit#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 + + + 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*](circuit#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 + + + 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*](circuit#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)") + + + ## Instruction-like methods + + [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") also contains a small number of methods that are very [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction")-like in detail. You may well find better integration and more API support if you first convert your circuit to an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") ([`to_instruction()`](#qiskit.circuit.QuantumCircuit.to_instruction "qiskit.circuit.QuantumCircuit.to_instruction")) or [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") ([`to_gate()`](#qiskit.circuit.QuantumCircuit.to_gate "qiskit.circuit.QuantumCircuit.to_gate")) as appropriate, then call the corresponding method. + + ### control + + + 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`. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. + + **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. + + + ### inverse + + + Invert (take adjoint of) this circuit. + + This is done by recursively inverting all gates. + + **Parameters** + + **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the inverse gate can be implemented as an annotated gate. + + **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) ├───── + └───────────┘ + ``` + + + ### power + + + Raise this circuit to the power of `power`. + + If `power` is a positive integer and both `matrix_power` and `annotated` are `False`, this implementation defaults to calling `repeat`. Otherwise, the circuit is converted into a gate, and a new circuit, containing this gate raised to the given power, is returned. The gate raised to the given power is implemented either as a unitary gate if `annotated` is `False` or as an annotated operation if `annotated` is `True`. + + **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)")) – indicates whether the inner power gate can be implemented as a unitary gate. + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the inner power gate can be implemented as an annotated operation. + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the circuit needs to be converted to a unitary gate, but is not unitary. + + **Returns** + + A circuit implementing this circuit raised to the power of `power`. + + **Return type** + + [QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + + ### repeat + + + 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") + + + ### 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) ├───── + └──────────┘ + ``` + + + ## Visualization + + Qiskit includes some drawing tools to give you a quick feel for what your circuit looks like. This tooling is primarily targeted at producing either a [Matplotlib](https://matplotlib.org/)- or text-based drawing. There is also a lesser-featured LaTeX backend for drawing, but this is only for simple circuits, and is not as actively maintained. + + + **[`qiskit.visualization`](visualization#module-qiskit.visualization "qiskit.visualization")** + + The primary documentation for all of Qiskit’s visualization tooling. + + + ### draw + + + 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)") *| None*) – 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)") *| None*) – 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)") *| None*) – File path to save image to. Defaults to `None` (result not saved in a file). + + * **style** ([*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)") *| None*) – + + Style name, file name of style JSON file, or a dictionary specifying the style. + + * The supported style names are `"iqp"` (default), `"iqp-dark"`, `"clifford"`, `"textbook"` and `"bw"`. + * If given a JSON file, e.g. `my_style.json` or `my_style` (the `.json` extension may be omitted), this function attempts to load the style dictionary from that location. Note, that the JSON file must completely specify the visualization specifications. The file is searched for in `qiskit/visualization/circuit/styles`, the current working directory, and the location specified in `~/.qiskit/settings.conf`. + * If a dictionary, every entry overrides the default configuration. If the `"name"` key is given, the default configuration is given by that style. For example, `{"name": "textbook", "subfontsize": 5}` loads the `"texbook"` style and sets the subfontsize (e.g. the gate angles) to `5`. + * If `None` the default style `"iqp"` is used or, if given, the default style specified in `~/.qiskit/settings.conf`. + + * **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)") *| None*) – 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** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – 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** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – `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)") *| None*) – 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** (*Any | None*) – Only used by the mpl backend. An optional `matplotlib.axes.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)")) – Adds $|0\rangle$ in the beginning of the qubit wires and $0$ to classical wires. Default is `False`. + + * **cregbundle** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If set to `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)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – 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)")) – 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` (if `output='text'`)** + + A drawing that can be printed as ascii art. + + * **`matplotlib.figure.Figure` (if `output='mpl'`)** + + A matplotlib figure object for the circuit diagram. + + * **`PIL.Image` (if `output='latex`’)** + + An in-memory representation of the image of the circuit diagram. + + * **`str` (if `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 + qc = QuantumCircuit(1, 1) + qc.h(0) + qc.measure(0, 0) + qc.draw(output='mpl', style={'backgroundcolor': '#EEEEEE'}) + ``` + + ![../\_images/qiskit-circuit-QuantumCircuit-5.png](/images/api/qiskit/qiskit-circuit-QuantumCircuit-5.png) + + + In addition to the core [`draw()`](#qiskit.circuit.QuantumCircuit.draw "qiskit.circuit.QuantumCircuit.draw") driver, there are two visualization-related helper methods, which are mostly useful for quickly unwrapping some inner instructions or reversing the [qubit-labelling conventions](circuit#circuit-conventions) in the drawing. For more general mutation, including basis-gate rewriting, you should use the transpiler ([`qiskit.transpiler`](transpiler#module-qiskit.transpiler "qiskit.transpiler")). + + ### decompose + + + 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") + + + ### 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 ├──■───────────────── + └───┘ + ``` + + + ## Internal utilities + + These functions are not intended for public use, but were accidentally left documented in the public API during the 1.0 release. They will be removed in Qiskit 2.0, but will be supported until then. + + ### cast + + + Best effort to cast value to type. Otherwise, returns the value. + + **Return type** + + *S* | *T* + + + ### cbit\_argument\_conversion + + + 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)")) + + + ### 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 + + + Return the prefix to use for auto naming. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### qbit\_argument\_conversion + + + 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](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")) diff --git a/docs/api/qiskit/qiskit.circuit.SwitchCaseOp.mdx b/docs/api/qiskit/qiskit.circuit.SwitchCaseOp.mdx index 8c6d8c2ebce..0ca4cc1ee8e 100644 --- a/docs/api/qiskit/qiskit.circuit.SwitchCaseOp.mdx +++ b/docs/api/qiskit/qiskit.circuit.SwitchCaseOp.mdx @@ -8,35 +8,16 @@ python_api_name: qiskit.circuit.SwitchCaseOp # SwitchCaseOp - + 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. + * **target** ([*Clbit*](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") *|*[*ClassicalRegister*](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") *|*[*expr.Expr*](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")) – the real-time 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 @@ -129,7 +110,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### params - return instruction params. + The parameters of this [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"). Ideally these will be gate angles. ### unit @@ -142,19 +123,19 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -173,7 +154,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -183,7 +164,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### 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. @@ -195,7 +176,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### 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. @@ -213,7 +194,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### copy - + Copy of the instruction. **Parameters** @@ -231,7 +212,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -255,14 +236,26 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### is\_parameterized - - Return True .IFF. instruction is parameterized else False + + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). + + + ### iter\_captured\_vars + + + Get an iterator over the unique captured variables in all blocks of this construct. + + **Return type** + + [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[expr.Var](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")] ### repeat - - Creates an instruction with gate repeated n amount of times. + + Creates an instruction with `self` repeated :math\`n\` times. + + If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. **Parameters** @@ -283,12 +276,33 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### replace\_blocks - - Replace blocks and return new instruction. :param blocks: Tuple of QuantumCircuits to replace in instruction. + + Return a new version of this control-flow operations with the [`blocks`](#qiskit.circuit.SwitchCaseOp.blocks "qiskit.circuit.SwitchCaseOp.blocks") mapped to the given new ones. + + Typically this is used in a workflow such as: + + ```python + existing_op = ... + + def map_block(block: QuantumCircuit) -> QuantumCircuit: + new_block = block.copy_empty_like() + # ... do something to `new_block` ... + return new_block + + new_op = existing_op.replace_blocks( + map_block(block) for block in existing_op.blocks + ) + ``` + + It is the caller’s responsibility to ensure that the mapped blocks are defined over a unified set of circuit resources, much like constructing a [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") using its default constructor. + + **Parameters** + + **blocks** (*Iterable\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – the new subcircuit blocks to use. **Returns** - New ControlFlowOp with replaced blocks. + New [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") with replaced blocks. **Return type** @@ -297,7 +311,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### 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. @@ -315,7 +329,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### soft\_compare - + 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** @@ -333,7 +347,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### 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. @@ -341,7 +355,7 @@ python_api_name: qiskit.circuit.SwitchCaseOp ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/qiskit.circuit.WhileLoopOp.mdx b/docs/api/qiskit/qiskit.circuit.WhileLoopOp.mdx index 68b37402a4b..aeabe06c262 100644 --- a/docs/api/qiskit/qiskit.circuit.WhileLoopOp.mdx +++ b/docs/api/qiskit/qiskit.circuit.WhileLoopOp.mdx @@ -8,49 +8,18 @@ python_api_name: qiskit.circuit.WhileLoopOp # WhileLoopOp - + 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. + * **condition** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*ClassicalRegister*](circuit#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*](circuit#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. ## Attributes @@ -155,19 +124,19 @@ python_api_name: qiskit.circuit.WhileLoopOp ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -186,7 +155,7 @@ python_api_name: qiskit.circuit.WhileLoopOp ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -196,7 +165,7 @@ python_api_name: qiskit.circuit.WhileLoopOp ### copy - + Copy of the instruction. **Parameters** @@ -214,7 +183,7 @@ python_api_name: qiskit.circuit.WhileLoopOp ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -238,14 +207,26 @@ python_api_name: qiskit.circuit.WhileLoopOp ### is\_parameterized - - Return True .IFF. instruction is parameterized else False + + Return whether the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") contains [compile-time parameters](circuit#circuit-compile-time-parameters). + + + ### iter\_captured\_vars + + + Get an iterator over the unique captured variables in all blocks of this construct. + + **Return type** + + [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[expr.Var](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")] ### repeat - - Creates an instruction with gate repeated n amount of times. + + Creates an instruction with `self` repeated :math\`n\` times. + + If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. **Parameters** @@ -266,17 +247,38 @@ python_api_name: qiskit.circuit.WhileLoopOp ### replace\_blocks - - Replace blocks and return new instruction. :param blocks: Tuple of QuantumCircuits to replace in instruction. + + Return a new version of this control-flow operations with the [`blocks`](#qiskit.circuit.WhileLoopOp.blocks "qiskit.circuit.WhileLoopOp.blocks") mapped to the given new ones. + + Typically this is used in a workflow such as: + + ```python + existing_op = ... + + def map_block(block: QuantumCircuit) -> QuantumCircuit: + new_block = block.copy_empty_like() + # ... do something to `new_block` ... + return new_block + + new_op = existing_op.replace_blocks( + map_block(block) for block in existing_op.blocks + ) + ``` + + It is the caller’s responsibility to ensure that the mapped blocks are defined over a unified set of circuit resources, much like constructing a [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") using its default constructor. + + **Parameters** + + **blocks** – the new subcircuit blocks to use. **Returns** - New ControlFlowOp with replaced blocks. + New [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") with replaced blocks. ### 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. @@ -294,7 +296,7 @@ python_api_name: qiskit.circuit.WhileLoopOp ### soft\_compare - + 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** @@ -312,7 +314,7 @@ python_api_name: qiskit.circuit.WhileLoopOp ### 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. @@ -320,7 +322,7 @@ python_api_name: qiskit.circuit.WhileLoopOp ### validate\_parameter - + Instruction parameters has no validation or normalization. diff --git a/docs/api/qiskit/qiskit.circuit.classicalfunction.BooleanExpression.mdx b/docs/api/qiskit/qiskit.circuit.classicalfunction.BooleanExpression.mdx index d0e5e48ecc3..4a663ecec87 100644 --- a/docs/api/qiskit/qiskit.circuit.classicalfunction.BooleanExpression.mdx +++ b/docs/api/qiskit/qiskit.circuit.classicalfunction.BooleanExpression.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression # BooleanExpression - + Bases: `ClassicalElement` The Boolean Expression gate. @@ -107,7 +107,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -120,19 +120,19 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + 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: @@ -185,7 +185,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -195,7 +195,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### control - + Return the controlled version of itself. Implemented either as a controlled gate (ref. [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). @@ -218,7 +218,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### copy - + Copy of the instruction. **Parameters** @@ -236,7 +236,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### from\_dimacs\_file - + Create a BooleanExpression from the string in the DIMACS format. :param filename: A file in DIMACS format. **Returns** @@ -254,7 +254,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -278,36 +278,37 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### is\_parameterized - - Return True .IFF. instruction is parameterized else False + + Return whether the `Instruction` contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### power - - Creates a unitary gate as gate^exponent. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. **Parameters** - **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Gate^exponent + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. **Returns** - To which to\_matrix is self.to\_matrix^exponent. - - **Return type** - - .library.UnitaryGate + An operation implementing `gate^exponent` **Raises** - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If Gate is not unitary + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary ### repeat - - Creates an instruction with gate repeated n amount of times. + + Creates an instruction with `self` repeated :math\`n\` times. + + If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. **Parameters** @@ -328,7 +329,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### 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. @@ -346,7 +347,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### simulate - + Evaluate the expression on a bitstring. This evaluation is done classically. @@ -366,7 +367,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### soft\_compare - + 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** @@ -384,7 +385,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### synth - + Synthesis the logic network into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). **Parameters** @@ -403,7 +404,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### to\_matrix - + Return a Numpy.array for the gate unitary matrix. **Returns** @@ -421,7 +422,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### 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. @@ -429,7 +430,7 @@ python_api_name: qiskit.circuit.classicalfunction.BooleanExpression ### validate\_parameter - + Gate parameters should be int, float, or ParameterExpression diff --git a/docs/api/qiskit/qiskit.circuit.classicalfunction.ClassicalFunction.mdx b/docs/api/qiskit/qiskit.circuit.classicalfunction.ClassicalFunction.mdx index ac84450da2a..3f6ba4fe72e 100644 --- a/docs/api/qiskit/qiskit.circuit.classicalfunction.ClassicalFunction.mdx +++ b/docs/api/qiskit/qiskit.circuit.classicalfunction.ClassicalFunction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction # ClassicalFunction - + Bases: `ClassicalElement` Represent a classical function and its logic network. @@ -126,7 +126,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### qregs @@ -171,19 +171,19 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### add\_decomposition - + Add a decomposition of the instruction to the SessionEquivalenceLibrary. ### assemble - + Assemble a QasmQobjInstruction ### broadcast\_arguments - + 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: @@ -236,7 +236,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### c\_if - + Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. @@ -246,13 +246,13 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### compile - + Parses and creates the logical circuit ### control - + Return the controlled version of itself. Implemented either as a controlled gate (ref. [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). @@ -275,7 +275,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### copy - + Copy of the instruction. **Parameters** @@ -293,7 +293,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -317,36 +317,37 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### is\_parameterized - - Return True .IFF. instruction is parameterized else False + + Return whether the `Instruction` contains [compile-time parameters](circuit#circuit-compile-time-parameters). ### power - - Creates a unitary gate as gate^exponent. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. **Parameters** - **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Gate^exponent + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. **Returns** - To which to\_matrix is self.to\_matrix^exponent. - - **Return type** - - .library.UnitaryGate + An operation implementing `gate^exponent` **Raises** - [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If Gate is not unitary + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary ### repeat - - Creates an instruction with gate repeated n amount of times. + + Creates an instruction with `self` repeated :math\`n\` times. + + If this operation has a conditional, the output instruction will have the same conditional and the inner repeated operations will be unconditional; instructions within a compound definition cannot be conditioned on registers within Qiskit’s data model. This means that it is not valid to apply a repeated instruction to a clbit that it both writes to and reads from in its condition. **Parameters** @@ -367,7 +368,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### 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. @@ -385,7 +386,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### simulate - + Evaluate the expression on a bitstring. This evaluation is done classically. @@ -405,7 +406,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### simulate\_all - + Returns a truth table. **Returns** @@ -419,7 +420,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### soft\_compare - + 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** @@ -437,7 +438,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### synth - + Synthesis the logic network into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). **Parameters** @@ -458,7 +459,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### to\_matrix - + Return a Numpy.array for the gate unitary matrix. **Returns** @@ -476,7 +477,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### 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. @@ -484,7 +485,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction ### validate\_parameter - + Gate parameters should be int, float, or ParameterExpression diff --git a/docs/api/qiskit/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.mdx b/docs/api/qiskit/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.mdx index 1aa89b64142..ffde80605fd 100644 --- a/docs/api/qiskit/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.mdx +++ b/docs/api/qiskit/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeE # qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError - + ClassicalFunction compiler type error. The classicalfunction function fails at type checking time. Set the error message. diff --git a/docs/api/qiskit/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.mdx b/docs/api/qiskit/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.mdx index 85768085a57..4db718ce921 100644 --- a/docs/api/qiskit/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.mdx +++ b/docs/api/qiskit/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.circuit.classicalfunction.ClassicalFunctionParseError # qiskit.circuit.classicalfunction.ClassicalFunctionParseError - + ClassicalFunction compiler parse error. The classicalfunction function fails at parsing time. Set the error message. diff --git a/docs/api/qiskit/qiskit.circuit.library.AND.mdx b/docs/api/qiskit/qiskit.circuit.library.AND.mdx index 2e30f9ea7a0..d689143ae57 100644 --- a/docs/api/qiskit/qiskit.circuit.library.AND.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.AND.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.AND # AND - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") A circuit implementing the logical AND operation on a number of qubits. @@ -36,7 +36,7 @@ python_api_name: qiskit.circuit.library.AND ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -50,13 +50,13 @@ python_api_name: qiskit.circuit.library.AND ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -70,12 +70,12 @@ python_api_name: qiskit.circuit.library.AND ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -90,9 +90,9 @@ python_api_name: qiskit.circuit.library.AND ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -101,12 +101,36 @@ python_api_name: qiskit.circuit.library.AND Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.AND.num_input_vars "qiskit.circuit.library.AND.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.AND.num_captured_vars "qiskit.circuit.library.AND.num_captured_vars") must be zero. + + ### num\_parameters @@ -119,6 +143,14 @@ python_api_name: qiskit.circuit.library.AND Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -200,7 +232,37 @@ python_api_name: qiskit.circuit.library.AND ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.AND.unit "qiskit.circuit.library.AND.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.AND.duration "qiskit.circuit.library.AND.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.C3SXGate.mdx b/docs/api/qiskit/qiskit.circuit.library.C3SXGate.mdx index 1a6bf169ea2..42cd0fc0d4a 100644 --- a/docs/api/qiskit/qiskit.circuit.library.C3SXGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.C3SXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.C3SXGate # C3SXGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") The 3-qubit controlled sqrt-X gate. @@ -24,7 +24,7 @@ python_api_name: qiskit.circuit.library.C3SXGate **Parameters** * **label** – An optional label for the gate \[Default: `None`] - * **ctrl\_state** – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **ctrl\_state** – control state expressed as integer, string (e.g. `'110'`), or `None`. If `None`, use all 1s. ## Attributes @@ -76,7 +76,7 @@ python_api_name: qiskit.circuit.library.C3SXGate ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.C3SXGate.ctrl_state "qiskit.circuit.library.C3SXGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration diff --git a/docs/api/qiskit/qiskit.circuit.library.C3XGate.mdx b/docs/api/qiskit/qiskit.circuit.library.C3XGate.mdx index 371bab43a75..c601cf906ad 100644 --- a/docs/api/qiskit/qiskit.circuit.library.C3XGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.C3XGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.C3XGate # C3XGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") The X gate controlled on 3 qubits. @@ -67,7 +67,7 @@ python_api_name: qiskit.circuit.library.C3XGate ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.C3XGate.ctrl_state "qiskit.circuit.library.C3XGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -154,14 +154,14 @@ python_api_name: qiskit.circuit.library.C3XGate ### control - + 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)") *| None*) – An optional label for the gate \[Default: `None`] - * **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*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **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*) – control state expressed as integer, string (e.g. `'110'`), or `None`. If `None`, use all 1s. * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. **Returns** @@ -175,7 +175,7 @@ python_api_name: qiskit.circuit.library.C3XGate ### inverse - + Invert this gate. The C3X is its own inverse. **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.C4XGate.mdx b/docs/api/qiskit/qiskit.circuit.library.C4XGate.mdx index df07e170881..d1058b22160 100644 --- a/docs/api/qiskit/qiskit.circuit.library.C4XGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.C4XGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.C4XGate # C4XGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") The 4-qubit controlled X gate. @@ -71,7 +71,7 @@ python_api_name: qiskit.circuit.library.C4XGate ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.C4XGate.ctrl_state "qiskit.circuit.library.C4XGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -158,14 +158,14 @@ python_api_name: qiskit.circuit.library.C4XGate ### control - + 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)") *| None*) – An optional label for the gate \[Default: `None`] - * **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*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **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*) – control state expressed as integer, string (e.g. `'110'`), or `None`. If `None`, use all 1s. * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. **Returns** @@ -179,7 +179,7 @@ python_api_name: qiskit.circuit.library.C4XGate ### inverse - + Invert this gate. The C4X is its own inverse. **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.CCXGate.mdx b/docs/api/qiskit/qiskit.circuit.library.CCXGate.mdx index 89bda3ac0c3..55f27ce0f60 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CCXGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CCXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CCXGate # CCXGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") CCX gate, also known as Toffoli gate. @@ -123,7 +123,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CCXGate.ctrl_state "qiskit.circuit.library.CCXGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -210,14 +210,14 @@ $$ ### control - + 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)") *| None*) – An optional label for the gate \[Default: `None`] - * **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*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **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*) – control state expressed as integer, string (e.g. `'110'`), or `None`. If `None`, use all 1s. * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. **Returns** @@ -231,7 +231,7 @@ $$ ### inverse - + Return an inverted CCX gate (also a CCX). **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.CCZGate.mdx b/docs/api/qiskit/qiskit.circuit.library.CCZGate.mdx index 59c35044279..8824f122105 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CCZGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CCZGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CCZGate # CCZGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") CCZ gate. @@ -98,7 +98,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CCZGate.ctrl_state "qiskit.circuit.library.CCZGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -185,7 +185,7 @@ $$ ### inverse - + Return inverted CCZ gate (itself). **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.CDKMRippleCarryAdder.mdx b/docs/api/qiskit/qiskit.circuit.library.CDKMRippleCarryAdder.mdx index 93f5401964f..7f2e7799cf1 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CDKMRippleCarryAdder.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CDKMRippleCarryAdder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CDKMRippleCarryAdder # CDKMRippleCarryAdder - + Bases: `Adder` A ripple-carry circuit to perform in-place addition on two qubit registers. @@ -82,7 +82,7 @@ python_api_name: qiskit.circuit.library.CDKMRippleCarryAdder ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -96,13 +96,13 @@ python_api_name: qiskit.circuit.library.CDKMRippleCarryAdder ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -116,12 +116,12 @@ python_api_name: qiskit.circuit.library.CDKMRippleCarryAdder ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -136,9 +136,9 @@ python_api_name: qiskit.circuit.library.CDKMRippleCarryAdder ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -147,12 +147,36 @@ python_api_name: qiskit.circuit.library.CDKMRippleCarryAdder Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.CDKMRippleCarryAdder.num_input_vars "qiskit.circuit.library.CDKMRippleCarryAdder.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.CDKMRippleCarryAdder.num_captured_vars "qiskit.circuit.library.CDKMRippleCarryAdder.num_captured_vars") must be zero. + + ### num\_parameters @@ -175,6 +199,14 @@ python_api_name: qiskit.circuit.library.CDKMRippleCarryAdder The number of state qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -256,7 +288,37 @@ python_api_name: qiskit.circuit.library.CDKMRippleCarryAdder ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.CDKMRippleCarryAdder.unit "qiskit.circuit.library.CDKMRippleCarryAdder.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.CDKMRippleCarryAdder.duration "qiskit.circuit.library.CDKMRippleCarryAdder.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.CHGate.mdx b/docs/api/qiskit/qiskit.circuit.library.CHGate.mdx index 16970de4f11..2cb381c36e9 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CHGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CHGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CHGate # CHGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-Hadamard gate. @@ -113,7 +113,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CHGate.ctrl_state "qiskit.circuit.library.CHGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -200,7 +200,7 @@ $$ ### inverse - + Return inverted CH gate (itself). diff --git a/docs/api/qiskit/qiskit.circuit.library.CPhaseGate.mdx b/docs/api/qiskit/qiskit.circuit.library.CPhaseGate.mdx index 564ee3d7b3c..a8478d4483c 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CPhaseGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CPhaseGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CPhaseGate # CPhaseGate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Controlled-Phase gate. @@ -94,7 +94,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CPhaseGate.ctrl_state "qiskit.circuit.library.CPhaseGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -181,7 +181,7 @@ $$ ### control - + Controlled version of this gate. **Parameters** @@ -202,14 +202,29 @@ $$ ### inverse - + Return inverted CPhase gate ($CPhase(\lambda)^{\dagger} = CPhase(-\lambda)$) ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.CRXGate.mdx b/docs/api/qiskit/qiskit.circuit.library.CRXGate.mdx index 9d045b16ab2..541ba942190 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CRXGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CRXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CRXGate # CRXGate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Controlled-RX gate. @@ -115,7 +115,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CRXGate.ctrl_state "qiskit.circuit.library.CRXGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -202,7 +202,7 @@ $$ ### inverse - + Return inverse CRX gate (i.e. with the negative rotation angle). **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.CRYGate.mdx b/docs/api/qiskit/qiskit.circuit.library.CRYGate.mdx index 9500b3d254b..d4994ee18e1 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CRYGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CRYGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CRYGate # CRYGate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Controlled-RY gate. @@ -115,7 +115,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CRYGate.ctrl_state "qiskit.circuit.library.CRYGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -202,7 +202,7 @@ $$ ### inverse - + Return inverse CRY gate (i.e. with the negative rotation angle) **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.CRZGate.mdx b/docs/api/qiskit/qiskit.circuit.library.CRZGate.mdx index a655f1d3fd6..2634260deef 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CRZGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CRZGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CRZGate # CRZGate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Controlled-RZ gate. @@ -117,7 +117,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CRZGate.ctrl_state "qiskit.circuit.library.CRZGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -204,7 +204,7 @@ $$ ### inverse - + Return inverse CRZ gate (i.e. with the negative rotation angle). **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.CSGate.mdx b/docs/api/qiskit/qiskit.circuit.library.CSGate.mdx index 110f57c1a98..6f2bb0e9cbc 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CSGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CSGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CSGate # CSGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-S gate. @@ -89,7 +89,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CSGate.ctrl_state "qiskit.circuit.library.CSGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -176,7 +176,7 @@ $$ ### inverse - + Return inverse of CSGate (CSdgGate). **Parameters** @@ -194,8 +194,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.CSXGate.mdx b/docs/api/qiskit/qiskit.circuit.library.CSXGate.mdx index 77c878380ec..a3cdea12757 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CSXGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CSXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CSXGate # CSXGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-√X gate. @@ -111,7 +111,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CSXGate.ctrl_state "qiskit.circuit.library.CSXGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration diff --git a/docs/api/qiskit/qiskit.circuit.library.CSdgGate.mdx b/docs/api/qiskit/qiskit.circuit.library.CSdgGate.mdx index f03e975a73f..c714ffc3313 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CSdgGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CSdgGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CSdgGate # CSdgGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-S^dagger gate. @@ -89,7 +89,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CSdgGate.ctrl_state "qiskit.circuit.library.CSdgGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -176,7 +176,7 @@ $$ ### inverse - + Return inverse of CSdgGate (CSGate). **Parameters** @@ -194,8 +194,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.CSwapGate.mdx b/docs/api/qiskit/qiskit.circuit.library.CSwapGate.mdx index 1a6ee9c5344..4120dce87ed 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CSwapGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CSwapGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CSwapGate # CSwapGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-SWAP gate, also known as the Fredkin gate. @@ -132,7 +132,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CSwapGate.ctrl_state "qiskit.circuit.library.CSwapGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -219,7 +219,7 @@ $$ ### inverse - + Return inverse CSwap gate (itself). **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.CU1Gate.mdx b/docs/api/qiskit/qiskit.circuit.library.CU1Gate.mdx index 8bdc29d0710..9f7db79dbb1 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CU1Gate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CU1Gate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CU1Gate # CU1Gate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Controlled-U1 gate. @@ -92,7 +92,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CU1Gate.ctrl_state "qiskit.circuit.library.CU1Gate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -179,7 +179,7 @@ $$ ### control - + Controlled version of this gate. **Parameters** @@ -200,7 +200,7 @@ $$ ### inverse - + Return inverted CU1 gate ($CU1(\lambda)^{\dagger} = CU1(-\lambda))$ **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.CU3Gate.mdx b/docs/api/qiskit/qiskit.circuit.library.CU3Gate.mdx index 2991e6d4e19..d4ee7691a6c 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CU3Gate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CU3Gate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CU3Gate # CU3Gate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Controlled-U3 gate (3-parameter two-qubit gate). @@ -117,7 +117,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CU3Gate.ctrl_state "qiskit.circuit.library.CU3Gate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -204,7 +204,7 @@ $$ ### inverse - + Return inverted CU3 gate. $CU3(\theta,\phi,\lambda)^{\dagger} =CU3(-\theta,-\phi,-\lambda))$ diff --git a/docs/api/qiskit/qiskit.circuit.library.CUGate.mdx b/docs/api/qiskit/qiskit.circuit.library.CUGate.mdx index 6e2e7c412cc..7d33686dd0a 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CUGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CUGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CUGate # CUGate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Controlled-U gate (4-parameter two-qubit gate). @@ -121,7 +121,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CUGate.ctrl_state "qiskit.circuit.library.CUGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -194,7 +194,7 @@ $$ ### inverse - + Return inverted CU gate. $CU(\theta,\phi,\lambda,\gamma)^{\dagger} = CU(-\theta,-\phi,-\lambda,-\gamma))$ diff --git a/docs/api/qiskit/qiskit.circuit.library.CXGate.mdx b/docs/api/qiskit/qiskit.circuit.library.CXGate.mdx index e897dee5b5c..236b8a72457 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CXGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CXGate # CXGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-X gate. @@ -119,7 +119,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CXGate.ctrl_state "qiskit.circuit.library.CXGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -206,14 +206,14 @@ $$ ### control - + 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)") *| None*) – An optional label for the gate \[Default: `None`] - * **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*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **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*) – control state expressed as integer, string (e.g. `'110'`), or `None`. If `None`, use all 1s. * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. **Returns** @@ -227,7 +227,7 @@ $$ ### inverse - + Return inverted CX gate (itself). **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.CYGate.mdx b/docs/api/qiskit/qiskit.circuit.library.CYGate.mdx index 44a4f68ea33..287c77d86ca 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CYGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CYGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CYGate # CYGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-Y gate. @@ -111,7 +111,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CYGate.ctrl_state "qiskit.circuit.library.CYGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -198,7 +198,7 @@ $$ ### inverse - + Return inverted CY gate (itself). **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.CZGate.mdx b/docs/api/qiskit/qiskit.circuit.library.CZGate.mdx index 98ba6894483..6f71854c14b 100644 --- a/docs/api/qiskit/qiskit.circuit.library.CZGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.CZGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.CZGate # CZGate - + Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") Controlled-Z gate. @@ -92,7 +92,7 @@ $$ ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.CZGate.ctrl_state "qiskit.circuit.library.CZGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -179,7 +179,7 @@ $$ ### inverse - + Return inverted CZ gate (itself). **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.DCXGate.mdx b/docs/api/qiskit/qiskit.circuit.library.DCXGate.mdx index 8a144b41125..09f25a1571a 100644 --- a/docs/api/qiskit/qiskit.circuit.library.DCXGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.DCXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.DCXGate # DCXGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") Double-CNOT gate. @@ -127,7 +127,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit diff --git a/docs/api/qiskit/qiskit.circuit.library.Diagonal.mdx b/docs/api/qiskit/qiskit.circuit.library.Diagonal.mdx index 0436ad346f5..da6addcf36c 100644 --- a/docs/api/qiskit/qiskit.circuit.library.Diagonal.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.Diagonal.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.Diagonal # Diagonal - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Diagonal circuit. @@ -64,7 +64,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -78,13 +78,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -98,12 +98,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -118,9 +118,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -129,12 +129,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.Diagonal.num_input_vars "qiskit.circuit.library.Diagonal.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.Diagonal.num_captured_vars "qiskit.circuit.library.Diagonal.num_captured_vars") must be zero. + + ### num\_parameters @@ -147,6 +171,14 @@ $$ Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -228,7 +260,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.Diagonal.unit "qiskit.circuit.library.Diagonal.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.Diagonal.duration "qiskit.circuit.library.Diagonal.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.DiagonalGate.mdx b/docs/api/qiskit/qiskit.circuit.library.DiagonalGate.mdx index c1af0918d61..052d786f88c 100644 --- a/docs/api/qiskit/qiskit.circuit.library.DiagonalGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.DiagonalGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.DiagonalGate # DiagonalGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Gate implementing a diagonal transformation. @@ -105,7 +105,7 @@ python_api_name: qiskit.circuit.library.DiagonalGate ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -118,13 +118,13 @@ python_api_name: qiskit.circuit.library.DiagonalGate ### inverse - + Return the inverse of the diagonal gate. ### validate\_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/qiskit.circuit.library.DraperQFTAdder.mdx b/docs/api/qiskit/qiskit.circuit.library.DraperQFTAdder.mdx index 28b4c8e44dd..7e791dd6205 100644 --- a/docs/api/qiskit/qiskit.circuit.library.DraperQFTAdder.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.DraperQFTAdder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.DraperQFTAdder # DraperQFTAdder - + Bases: `Adder` A circuit that uses QFT to perform in-place addition on two qubit registers. @@ -53,7 +53,7 @@ python_api_name: qiskit.circuit.library.DraperQFTAdder ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -67,13 +67,13 @@ python_api_name: qiskit.circuit.library.DraperQFTAdder ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -87,12 +87,12 @@ python_api_name: qiskit.circuit.library.DraperQFTAdder ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -107,9 +107,9 @@ python_api_name: qiskit.circuit.library.DraperQFTAdder ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -118,12 +118,36 @@ python_api_name: qiskit.circuit.library.DraperQFTAdder Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.DraperQFTAdder.num_input_vars "qiskit.circuit.library.DraperQFTAdder.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.DraperQFTAdder.num_captured_vars "qiskit.circuit.library.DraperQFTAdder.num_captured_vars") must be zero. + + ### num\_parameters @@ -146,6 +170,14 @@ python_api_name: qiskit.circuit.library.DraperQFTAdder The number of state qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -227,7 +259,37 @@ python_api_name: qiskit.circuit.library.DraperQFTAdder ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.DraperQFTAdder.unit "qiskit.circuit.library.DraperQFTAdder.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.DraperQFTAdder.duration "qiskit.circuit.library.DraperQFTAdder.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.ECRGate.mdx b/docs/api/qiskit/qiskit.circuit.library.ECRGate.mdx index 948207bf8ee..8e4aeaf600d 100644 --- a/docs/api/qiskit/qiskit.circuit.library.ECRGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.ECRGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.ECRGate # ECRGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") An echoed cross-resonance gate. @@ -151,7 +151,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -164,7 +164,7 @@ $$ ### inverse - + Return inverse ECR gate (itself). **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.EfficientSU2.mdx b/docs/api/qiskit/qiskit.circuit.library.EfficientSU2.mdx index 02b85d1ab6c..6d241fa80b9 100644 --- a/docs/api/qiskit/qiskit.circuit.library.EfficientSU2.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.EfficientSU2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.EfficientSU2 # EfficientSU2 - + Bases: [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.n_local.two_local.TwoLocal") The hardware efficient SU(2) 2-local circuit. @@ -66,7 +66,7 @@ python_api_name: qiskit.circuit.library.EfficientSU2 * **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. + * **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’, ‘pairwise’, ‘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. Defaults 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. @@ -79,7 +79,7 @@ python_api_name: qiskit.circuit.library.EfficientSU2 ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -93,7 +93,7 @@ python_api_name: qiskit.circuit.library.EfficientSU2 ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -129,7 +129,7 @@ python_api_name: qiskit.circuit.library.EfficientSU2 ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -154,7 +154,7 @@ python_api_name: qiskit.circuit.library.EfficientSU2 ### instances - + ### layout @@ -169,9 +169,9 @@ python_api_name: qiskit.circuit.library.EfficientSU2 ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -180,12 +180,36 @@ python_api_name: qiskit.circuit.library.EfficientSU2 Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.EfficientSU2.num_input_vars "qiskit.circuit.library.EfficientSU2.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.EfficientSU2.num_captured_vars "qiskit.circuit.library.EfficientSU2.num_captured_vars") must be zero. + + ### num\_layers @@ -226,6 +250,14 @@ python_api_name: qiskit.circuit.library.EfficientSU2 The number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -299,13 +331,13 @@ python_api_name: qiskit.circuit.library.EfficientSU2 ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -327,5 +359,29 @@ python_api_name: qiskit.circuit.library.EfficientSU2 The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.EfficientSU2.unit "qiskit.circuit.library.EfficientSU2.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.EfficientSU2.duration "qiskit.circuit.library.EfficientSU2.duration") is specified in. + diff --git a/docs/api/qiskit/qiskit.circuit.library.EvolvedOperatorAnsatz.mdx b/docs/api/qiskit/qiskit.circuit.library.EvolvedOperatorAnsatz.mdx index ffd7a4f5560..c57a7f477f2 100644 --- a/docs/api/qiskit/qiskit.circuit.library.EvolvedOperatorAnsatz.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.EvolvedOperatorAnsatz.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz # EvolvedOperatorAnsatz - + Bases: [`NLocal`](qiskit.circuit.library.NLocal "qiskit.circuit.library.n_local.n_local.NLocal") The evolved operator ansatz. @@ -29,7 +29,7 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -43,7 +43,7 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -93,7 +93,7 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -118,7 +118,7 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz ### instances - + ### layout @@ -133,9 +133,9 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -144,12 +144,36 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.EvolvedOperatorAnsatz.num_input_vars "qiskit.circuit.library.EvolvedOperatorAnsatz.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.EvolvedOperatorAnsatz.num_captured_vars "qiskit.circuit.library.EvolvedOperatorAnsatz.num_captured_vars") must be zero. + + ### num\_layers @@ -190,6 +214,14 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz The number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -273,13 +305,13 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -301,5 +333,29 @@ python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.EvolvedOperatorAnsatz.unit "qiskit.circuit.library.EvolvedOperatorAnsatz.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.EvolvedOperatorAnsatz.duration "qiskit.circuit.library.EvolvedOperatorAnsatz.duration") is specified in. + diff --git a/docs/api/qiskit/qiskit.circuit.library.ExactReciprocal.mdx b/docs/api/qiskit/qiskit.circuit.library.ExactReciprocal.mdx index 578eb8ada17..321ca3f8375 100644 --- a/docs/api/qiskit/qiskit.circuit.library.ExactReciprocal.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.ExactReciprocal.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.ExactReciprocal # ExactReciprocal - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Exact reciprocal @@ -33,7 +33,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -47,13 +47,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -67,12 +67,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -87,9 +87,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -98,12 +98,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.ExactReciprocal.num_input_vars "qiskit.circuit.library.ExactReciprocal.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.ExactReciprocal.num_captured_vars "qiskit.circuit.library.ExactReciprocal.num_captured_vars") must be zero. + + ### num\_parameters @@ -116,6 +140,14 @@ $$ Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -197,7 +229,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.ExactReciprocal.unit "qiskit.circuit.library.ExactReciprocal.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.ExactReciprocal.duration "qiskit.circuit.library.ExactReciprocal.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.ExcitationPreserving.mdx b/docs/api/qiskit/qiskit.circuit.library.ExcitationPreserving.mdx index c0f28e463ab..a9478feede6 100644 --- a/docs/api/qiskit/qiskit.circuit.library.ExcitationPreserving.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.ExcitationPreserving.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.ExcitationPreserving # ExcitationPreserving - + Bases: [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.n_local.two_local.TwoLocal") The heuristic excitation-preserving wave function ansatz. @@ -98,7 +98,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -112,7 +112,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -148,7 +148,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -173,7 +173,7 @@ $$ ### instances - + ### layout @@ -188,9 +188,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -199,12 +199,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.ExcitationPreserving.num_input_vars "qiskit.circuit.library.ExcitationPreserving.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.ExcitationPreserving.num_captured_vars "qiskit.circuit.library.ExcitationPreserving.num_captured_vars") must be zero. + + ### num\_layers @@ -245,6 +269,14 @@ $$ The number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -318,13 +350,13 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -346,5 +378,29 @@ $$ The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.ExcitationPreserving.unit "qiskit.circuit.library.ExcitationPreserving.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.ExcitationPreserving.duration "qiskit.circuit.library.ExcitationPreserving.duration") is specified in. + diff --git a/docs/api/qiskit/qiskit.circuit.library.FourierChecking.mdx b/docs/api/qiskit/qiskit.circuit.library.FourierChecking.mdx index a5a70712d46..6f0cec7f090 100644 --- a/docs/api/qiskit/qiskit.circuit.library.FourierChecking.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.FourierChecking.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.FourierChecking # FourierChecking - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Fourier checking circuit. @@ -47,7 +47,7 @@ python_api_name: qiskit.circuit.library.FourierChecking ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -61,13 +61,13 @@ python_api_name: qiskit.circuit.library.FourierChecking ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -81,12 +81,12 @@ python_api_name: qiskit.circuit.library.FourierChecking ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -101,9 +101,9 @@ python_api_name: qiskit.circuit.library.FourierChecking ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -112,12 +112,36 @@ python_api_name: qiskit.circuit.library.FourierChecking Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.FourierChecking.num_input_vars "qiskit.circuit.library.FourierChecking.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.FourierChecking.num_captured_vars "qiskit.circuit.library.FourierChecking.num_captured_vars") must be zero. + + ### num\_parameters @@ -130,6 +154,14 @@ python_api_name: qiskit.circuit.library.FourierChecking Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -211,7 +243,37 @@ python_api_name: qiskit.circuit.library.FourierChecking ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.FourierChecking.unit "qiskit.circuit.library.FourierChecking.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.FourierChecking.duration "qiskit.circuit.library.FourierChecking.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.FunctionalPauliRotations.mdx b/docs/api/qiskit/qiskit.circuit.library.FunctionalPauliRotations.mdx index 075132b3a62..0fd936b14a0 100644 --- a/docs/api/qiskit/qiskit.circuit.library.FunctionalPauliRotations.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.FunctionalPauliRotations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.FunctionalPauliRotations # FunctionalPauliRotations - + Bases: `BlueprintCircuit`, [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Base class for functional Pauli rotations. @@ -26,7 +26,7 @@ python_api_name: qiskit.circuit.library.FunctionalPauliRotations ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### basis @@ -52,7 +52,7 @@ python_api_name: qiskit.circuit.library.FunctionalPauliRotations ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -62,12 +62,12 @@ python_api_name: qiskit.circuit.library.FunctionalPauliRotations ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -82,9 +82,9 @@ python_api_name: qiskit.circuit.library.FunctionalPauliRotations ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancilla\_qubits @@ -103,12 +103,36 @@ python_api_name: qiskit.circuit.library.FunctionalPauliRotations Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.FunctionalPauliRotations.num_input_vars "qiskit.circuit.library.FunctionalPauliRotations.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.FunctionalPauliRotations.num_captured_vars "qiskit.circuit.library.FunctionalPauliRotations.num_captured_vars") must be zero. + + ### num\_parameters @@ -129,6 +153,14 @@ python_api_name: qiskit.circuit.library.FunctionalPauliRotations The number of state qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -156,13 +188,37 @@ python_api_name: qiskit.circuit.library.FunctionalPauliRotations ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.FunctionalPauliRotations.unit "qiskit.circuit.library.FunctionalPauliRotations.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.FunctionalPauliRotations.duration "qiskit.circuit.library.FunctionalPauliRotations.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.GMS.mdx b/docs/api/qiskit/qiskit.circuit.library.GMS.mdx index 709104f6945..d887ad8ac01 100644 --- a/docs/api/qiskit/qiskit.circuit.library.GMS.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.GMS.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GMS # GMS - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Global Mølmer–Sørensen gate. @@ -56,7 +56,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -70,13 +70,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -90,12 +90,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -110,9 +110,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -121,12 +121,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.GMS.num_input_vars "qiskit.circuit.library.GMS.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.GMS.num_captured_vars "qiskit.circuit.library.GMS.num_captured_vars") must be zero. + + ### num\_parameters @@ -139,6 +163,14 @@ $$ Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -220,7 +252,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.GMS.unit "qiskit.circuit.library.GMS.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.GMS.duration "qiskit.circuit.library.GMS.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.GR.mdx b/docs/api/qiskit/qiskit.circuit.library.GR.mdx index 6f71307296f..7d50dfb17c6 100644 --- a/docs/api/qiskit/qiskit.circuit.library.GR.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.GR.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GR # GR - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Global R gate. @@ -50,7 +50,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -64,13 +64,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -84,12 +84,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -104,9 +104,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -115,12 +115,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.GR.num_input_vars "qiskit.circuit.library.GR.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.GR.num_captured_vars "qiskit.circuit.library.GR.num_captured_vars") must be zero. + + ### num\_parameters @@ -133,6 +157,14 @@ $$ Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -214,7 +246,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.GR.unit "qiskit.circuit.library.GR.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.GR.duration "qiskit.circuit.library.GR.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.GRX.mdx b/docs/api/qiskit/qiskit.circuit.library.GRX.mdx index 5761577c4cd..273b56862cc 100644 --- a/docs/api/qiskit/qiskit.circuit.library.GRX.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.GRX.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GRX # GRX - + Bases: [`GR`](qiskit.circuit.library.GR "qiskit.circuit.library.generalized_gates.gr.GR") Global RX gate. @@ -49,7 +49,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -63,13 +63,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -83,12 +83,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -103,9 +103,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -114,12 +114,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.GRX.num_input_vars "qiskit.circuit.library.GRX.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.GRX.num_captured_vars "qiskit.circuit.library.GRX.num_captured_vars") must be zero. + + ### num\_parameters @@ -132,6 +156,14 @@ $$ Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -213,7 +245,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.GRX.unit "qiskit.circuit.library.GRX.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.GRX.duration "qiskit.circuit.library.GRX.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.GRY.mdx b/docs/api/qiskit/qiskit.circuit.library.GRY.mdx index 4d9b3c97af8..631686943ae 100644 --- a/docs/api/qiskit/qiskit.circuit.library.GRY.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.GRY.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GRY # GRY - + Bases: [`GR`](qiskit.circuit.library.GR "qiskit.circuit.library.generalized_gates.gr.GR") Global RY gate. @@ -49,7 +49,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -63,13 +63,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -83,12 +83,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -103,9 +103,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -114,12 +114,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.GRY.num_input_vars "qiskit.circuit.library.GRY.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.GRY.num_captured_vars "qiskit.circuit.library.GRY.num_captured_vars") must be zero. + + ### num\_parameters @@ -132,6 +156,14 @@ $$ Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -213,7 +245,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.GRY.unit "qiskit.circuit.library.GRY.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.GRY.duration "qiskit.circuit.library.GRY.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.GRZ.mdx b/docs/api/qiskit/qiskit.circuit.library.GRZ.mdx index 4b8617880f8..83039020348 100644 --- a/docs/api/qiskit/qiskit.circuit.library.GRZ.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.GRZ.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GRZ # GRZ - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Global RZ gate. @@ -49,7 +49,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -63,13 +63,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -83,12 +83,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -103,9 +103,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -114,12 +114,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.GRZ.num_input_vars "qiskit.circuit.library.GRZ.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.GRZ.num_captured_vars "qiskit.circuit.library.GRZ.num_captured_vars") must be zero. + + ### num\_parameters @@ -132,6 +156,14 @@ $$ Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -213,7 +245,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.GRZ.unit "qiskit.circuit.library.GRZ.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.GRZ.duration "qiskit.circuit.library.GRZ.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.GlobalPhaseGate.mdx b/docs/api/qiskit/qiskit.circuit.library.GlobalPhaseGate.mdx index 3b9b9fafc21..4b9558d26b6 100644 --- a/docs/api/qiskit/qiskit.circuit.library.GlobalPhaseGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.GlobalPhaseGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GlobalPhaseGate # GlobalPhaseGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") The global phase gate ($e^{i\theta}$). @@ -119,7 +119,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -132,7 +132,7 @@ $$ ### inverse - + Return inverse GlobalPhaseGate gate. $\text{GlobalPhaseGate}(\lambda)^{\dagger} = \text{GlobalPhaseGate}(-\lambda)$ diff --git a/docs/api/qiskit/qiskit.circuit.library.GraphState.mdx b/docs/api/qiskit/qiskit.circuit.library.GraphState.mdx index a2d25c4e363..18fa0835bec 100644 --- a/docs/api/qiskit/qiskit.circuit.library.GraphState.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.GraphState.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GraphState # GraphState - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Circuit to prepare a graph state. @@ -54,7 +54,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -68,13 +68,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -88,12 +88,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -108,9 +108,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -119,12 +119,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.GraphState.num_input_vars "qiskit.circuit.library.GraphState.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.GraphState.num_captured_vars "qiskit.circuit.library.GraphState.num_captured_vars") must be zero. + + ### num\_parameters @@ -137,6 +161,14 @@ $$ Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -218,7 +250,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.GraphState.unit "qiskit.circuit.library.GraphState.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.GraphState.duration "qiskit.circuit.library.GraphState.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.GroverOperator.mdx b/docs/api/qiskit/qiskit.circuit.library.GroverOperator.mdx index 244af4ff931..11e588fbd12 100644 --- a/docs/api/qiskit/qiskit.circuit.library.GroverOperator.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.GroverOperator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.GroverOperator # GroverOperator - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") The Grover operator. @@ -165,7 +165,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -179,13 +179,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -199,12 +199,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -219,9 +219,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -230,12 +230,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.GroverOperator.num_input_vars "qiskit.circuit.library.GroverOperator.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.GroverOperator.num_captured_vars "qiskit.circuit.library.GroverOperator.num_captured_vars") must be zero. + + ### num\_parameters @@ -248,6 +272,14 @@ $$ Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -335,7 +367,7 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reflection\_qubits @@ -355,5 +387,35 @@ $$ The subcircuit implementing the reflection about 0. + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.GroverOperator.unit "qiskit.circuit.library.GroverOperator.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.GroverOperator.duration "qiskit.circuit.library.GroverOperator.duration") is specified in. + diff --git a/docs/api/qiskit/qiskit.circuit.library.HGate.mdx b/docs/api/qiskit/qiskit.circuit.library.HGate.mdx index 530145d5f2b..0a09fe6e5e4 100644 --- a/docs/api/qiskit/qiskit.circuit.library.HGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.HGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.HGate # HGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") Single-qubit Hadamard gate. @@ -125,7 +125,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -138,7 +138,7 @@ $$ ### control - + Return a (multi-)controlled-H gate. One control qubit returns a CH gate. @@ -161,7 +161,7 @@ $$ ### inverse - + Return inverted H gate (itself). **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.HRSCumulativeMultiplier.mdx b/docs/api/qiskit/qiskit.circuit.library.HRSCumulativeMultiplier.mdx index 817b0587467..919786e0128 100644 --- a/docs/api/qiskit/qiskit.circuit.library.HRSCumulativeMultiplier.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.HRSCumulativeMultiplier.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.HRSCumulativeMultiplier # HRSCumulativeMultiplier - + Bases: `Multiplier` A multiplication circuit to store product of two input registers out-of-place. @@ -66,7 +66,7 @@ python_api_name: qiskit.circuit.library.HRSCumulativeMultiplier ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -80,13 +80,13 @@ python_api_name: qiskit.circuit.library.HRSCumulativeMultiplier ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -100,12 +100,12 @@ python_api_name: qiskit.circuit.library.HRSCumulativeMultiplier ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -120,9 +120,9 @@ python_api_name: qiskit.circuit.library.HRSCumulativeMultiplier ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -131,12 +131,36 @@ python_api_name: qiskit.circuit.library.HRSCumulativeMultiplier Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.HRSCumulativeMultiplier.num_input_vars "qiskit.circuit.library.HRSCumulativeMultiplier.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.HRSCumulativeMultiplier.num_captured_vars "qiskit.circuit.library.HRSCumulativeMultiplier.num_captured_vars") must be zero. + + ### num\_parameters @@ -169,6 +193,14 @@ python_api_name: qiskit.circuit.library.HRSCumulativeMultiplier The number of state qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -250,7 +282,37 @@ python_api_name: qiskit.circuit.library.HRSCumulativeMultiplier ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.HRSCumulativeMultiplier.unit "qiskit.circuit.library.HRSCumulativeMultiplier.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.HRSCumulativeMultiplier.duration "qiskit.circuit.library.HRSCumulativeMultiplier.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.HamiltonianGate.mdx b/docs/api/qiskit/qiskit.circuit.library.HamiltonianGate.mdx index 5b30b52a0c9..5918611a2e9 100644 --- a/docs/api/qiskit/qiskit.circuit.library.HamiltonianGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.HamiltonianGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.HamiltonianGate # HamiltonianGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Class for representing evolution by a Hamiltonian operator as a gate. @@ -113,7 +113,7 @@ python_api_name: qiskit.circuit.library.HamiltonianGate ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -126,31 +126,31 @@ python_api_name: qiskit.circuit.library.HamiltonianGate ### adjoint - + Return the adjoint of the unitary. ### conjugate - + Return the conjugate of the Hamiltonian. ### inverse - + Return the adjoint of the unitary. ### transpose - + Return the transpose of the Hamiltonian. ### validate\_parameter - + Hamiltonian parameter has to be an ndarray, operator or float. diff --git a/docs/api/qiskit/qiskit.circuit.library.HiddenLinearFunction.mdx b/docs/api/qiskit/qiskit.circuit.library.HiddenLinearFunction.mdx index 65a1266d1e0..371dad9864d 100644 --- a/docs/api/qiskit/qiskit.circuit.library.HiddenLinearFunction.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.HiddenLinearFunction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.HiddenLinearFunction # HiddenLinearFunction - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Circuit to solve the hidden linear function problem. @@ -56,7 +56,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -70,13 +70,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -90,12 +90,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -110,9 +110,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -121,12 +121,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.HiddenLinearFunction.num_input_vars "qiskit.circuit.library.HiddenLinearFunction.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.HiddenLinearFunction.num_captured_vars "qiskit.circuit.library.HiddenLinearFunction.num_captured_vars") must be zero. + + ### num\_parameters @@ -139,6 +163,14 @@ $$ Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -220,7 +252,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.HiddenLinearFunction.unit "qiskit.circuit.library.HiddenLinearFunction.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.HiddenLinearFunction.duration "qiskit.circuit.library.HiddenLinearFunction.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.IGate.mdx b/docs/api/qiskit/qiskit.circuit.library.IGate.mdx index f1a108eba4d..1a9124ac5f3 100644 --- a/docs/api/qiskit/qiskit.circuit.library.IGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.IGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.IGate # IGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") Identity gate. @@ -124,7 +124,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -137,7 +137,7 @@ $$ ### inverse - + Returne the inverse gate (itself). **Parameters** @@ -157,8 +157,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.IQP.mdx b/docs/api/qiskit/qiskit.circuit.library.IQP.mdx index f36675ce4f4..7706c4340c3 100644 --- a/docs/api/qiskit/qiskit.circuit.library.IQP.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.IQP.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.IQP # IQP - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Instantaneous quantum polynomial (IQP) circuit. @@ -44,7 +44,7 @@ python_api_name: qiskit.circuit.library.IQP ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -58,13 +58,13 @@ python_api_name: qiskit.circuit.library.IQP ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -78,12 +78,12 @@ python_api_name: qiskit.circuit.library.IQP ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -98,9 +98,9 @@ python_api_name: qiskit.circuit.library.IQP ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -109,12 +109,36 @@ python_api_name: qiskit.circuit.library.IQP Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.IQP.num_input_vars "qiskit.circuit.library.IQP.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.IQP.num_captured_vars "qiskit.circuit.library.IQP.num_captured_vars") must be zero. + + ### num\_parameters @@ -127,6 +151,14 @@ python_api_name: qiskit.circuit.library.IQP Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -208,7 +240,37 @@ python_api_name: qiskit.circuit.library.IQP ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.IQP.unit "qiskit.circuit.library.IQP.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.IQP.duration "qiskit.circuit.library.IQP.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.Initialize.mdx b/docs/api/qiskit/qiskit.circuit.library.Initialize.mdx index e99512fe31f..d65856b48b4 100644 --- a/docs/api/qiskit/qiskit.circuit.library.Initialize.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.Initialize.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.Initialize # Initialize - + Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") Complex amplitude initialization. @@ -130,7 +130,7 @@ python_api_name: qiskit.circuit.library.Initialize ### broadcast\_arguments - + Validation of the arguments. **Parameters** @@ -149,7 +149,7 @@ python_api_name: qiskit.circuit.library.Initialize ### gates\_to\_uncompute - + Call to create a circuit with gates that take the desired vector to zero. **Returns** diff --git a/docs/api/qiskit/qiskit.circuit.library.InnerProduct.mdx b/docs/api/qiskit/qiskit.circuit.library.InnerProduct.mdx index 93976f210f5..19f7fdbddf0 100644 --- a/docs/api/qiskit/qiskit.circuit.library.InnerProduct.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.InnerProduct.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.InnerProduct # InnerProduct - + 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$. @@ -55,7 +55,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -69,13 +69,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -89,12 +89,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -109,9 +109,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -120,12 +120,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.InnerProduct.num_input_vars "qiskit.circuit.library.InnerProduct.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.InnerProduct.num_captured_vars "qiskit.circuit.library.InnerProduct.num_captured_vars") must be zero. + + ### num\_parameters @@ -138,6 +162,14 @@ $$ Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -219,7 +251,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.InnerProduct.unit "qiskit.circuit.library.InnerProduct.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.InnerProduct.duration "qiskit.circuit.library.InnerProduct.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.IntegerComparator.mdx b/docs/api/qiskit/qiskit.circuit.library.IntegerComparator.mdx index 5ddc4247be8..c0ab51351c0 100644 --- a/docs/api/qiskit/qiskit.circuit.library.IntegerComparator.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.IntegerComparator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.IntegerComparator # IntegerComparator - + Bases: `BlueprintCircuit` Integer Comparator. @@ -35,7 +35,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -49,7 +49,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -69,12 +69,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -89,9 +89,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -100,12 +100,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.IntegerComparator.num_input_vars "qiskit.circuit.library.IntegerComparator.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.IntegerComparator.num_captured_vars "qiskit.circuit.library.IntegerComparator.num_captured_vars") must be zero. + + ### num\_parameters @@ -126,6 +150,14 @@ $$ The number of state qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -153,13 +185,13 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### value @@ -171,5 +203,29 @@ $$ The value against which the value of the qubit register is compared. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.IntegerComparator.unit "qiskit.circuit.library.IntegerComparator.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.IntegerComparator.duration "qiskit.circuit.library.IntegerComparator.duration") is specified in. + diff --git a/docs/api/qiskit/qiskit.circuit.library.Isometry.mdx b/docs/api/qiskit/qiskit.circuit.library.Isometry.mdx index 7490f159007..ef8c437939a 100644 --- a/docs/api/qiskit/qiskit.circuit.library.Isometry.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.Isometry.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.Isometry # Isometry - + Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") Decomposition of arbitrary isometries from $m$ to $n$ qubits. @@ -118,7 +118,7 @@ python_api_name: qiskit.circuit.library.Isometry ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -131,13 +131,13 @@ python_api_name: qiskit.circuit.library.Isometry ### inv\_gate - + Return the adjoint of the unitary. ### inverse - + Invert this instruction. If annotated is False, the inverse instruction is implemented as a fresh instruction with the recursively inverted definition. @@ -161,7 +161,7 @@ python_api_name: qiskit.circuit.library.Isometry ### validate\_parameter - + Isometry parameter has to be an ndarray. diff --git a/docs/api/qiskit/qiskit.circuit.library.LinearAmplitudeFunction.mdx b/docs/api/qiskit/qiskit.circuit.library.LinearAmplitudeFunction.mdx index da618c621a1..2a4267344e3 100644 --- a/docs/api/qiskit/qiskit.circuit.library.LinearAmplitudeFunction.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.LinearAmplitudeFunction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.LinearAmplitudeFunction # LinearAmplitudeFunction - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") A circuit implementing a (piecewise) linear function on qubit amplitudes. @@ -70,7 +70,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -84,13 +84,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -104,12 +104,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -124,9 +124,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -135,12 +135,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.LinearAmplitudeFunction.num_input_vars "qiskit.circuit.library.LinearAmplitudeFunction.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.LinearAmplitudeFunction.num_captured_vars "qiskit.circuit.library.LinearAmplitudeFunction.num_captured_vars") must be zero. + + ### num\_parameters @@ -153,6 +177,14 @@ $$ Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -234,14 +266,44 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.LinearAmplitudeFunction.unit "qiskit.circuit.library.LinearAmplitudeFunction.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.LinearAmplitudeFunction.duration "qiskit.circuit.library.LinearAmplitudeFunction.duration") is specified in. ## Methods ### post\_processing - + Map the function value of the approximated $\hat{f}$ to $f$. **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.LinearFunction.mdx b/docs/api/qiskit/qiskit.circuit.library.LinearFunction.mdx index 01329e53942..73e23a4d968 100644 --- a/docs/api/qiskit/qiskit.circuit.library.LinearFunction.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.LinearFunction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.LinearFunction # LinearFunction - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") A linear reversible circuit on n qubits. @@ -154,7 +154,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -167,7 +167,7 @@ $$ ### extend\_with\_identity - + Extend linear function to a linear function over nq qubits, with identities on other subsystems. **Parameters** @@ -186,13 +186,13 @@ $$ ### function\_str - + Return string representation of the linear function viewed as a linear transformation. ### 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** @@ -202,19 +202,19 @@ $$ ### mat\_str - + Return string representation of the linear function viewed as a matrix with 0/1 entries. ### 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 - + Synthesizes the linear function into a quantum circuit. **Returns** @@ -228,7 +228,7 @@ $$ ### validate\_parameter - + Parameter validation diff --git a/docs/api/qiskit/qiskit.circuit.library.LinearPauliRotations.mdx b/docs/api/qiskit/qiskit.circuit.library.LinearPauliRotations.mdx index 9a1a146f2e1..f0bc2e11fcc 100644 --- a/docs/api/qiskit/qiskit.circuit.library.LinearPauliRotations.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.LinearPauliRotations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.LinearPauliRotations # LinearPauliRotations - + Bases: [`FunctionalPauliRotations`](qiskit.circuit.library.FunctionalPauliRotations "qiskit.circuit.library.arithmetic.functional_pauli_rotations.FunctionalPauliRotations") Linearly-controlled X, Y or Z rotation. @@ -49,7 +49,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### basis @@ -75,7 +75,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -85,12 +85,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -105,9 +105,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancilla\_qubits @@ -126,12 +126,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.LinearPauliRotations.num_input_vars "qiskit.circuit.library.LinearPauliRotations.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.LinearPauliRotations.num_captured_vars "qiskit.circuit.library.LinearPauliRotations.num_captured_vars") must be zero. + + ### num\_parameters @@ -152,6 +176,14 @@ $$ The number of state qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### offset @@ -191,13 +223,13 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### slope @@ -211,5 +243,29 @@ $$ The rotation angle common in all controlled rotations. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.LinearPauliRotations.unit "qiskit.circuit.library.LinearPauliRotations.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.LinearPauliRotations.duration "qiskit.circuit.library.LinearPauliRotations.duration") is specified in. + diff --git a/docs/api/qiskit/qiskit.circuit.library.MCMT.mdx b/docs/api/qiskit/qiskit.circuit.library.MCMT.mdx index 70592a0d5dd..0cb2cf0dcd1 100644 --- a/docs/api/qiskit/qiskit.circuit.library.MCMT.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.MCMT.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MCMT # MCMT - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") The multi-controlled multi-target gate, for an arbitrary singly controlled target gate. @@ -34,7 +34,7 @@ python_api_name: qiskit.circuit.library.MCMT **Parameters** - * **gate** ([*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate") *| Callable\[\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*,* [*circuit.Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*,* [*circuit.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. + * **gate** ([*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate") *| Callable\[\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*,* [*circuit.Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*,* [*circuit.Qubit*](circuit#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. @@ -48,7 +48,7 @@ python_api_name: qiskit.circuit.library.MCMT ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -62,13 +62,13 @@ python_api_name: qiskit.circuit.library.MCMT ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -82,12 +82,12 @@ python_api_name: qiskit.circuit.library.MCMT ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -102,9 +102,9 @@ python_api_name: qiskit.circuit.library.MCMT ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancilla\_qubits @@ -119,12 +119,36 @@ python_api_name: qiskit.circuit.library.MCMT Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.MCMT.num_input_vars "qiskit.circuit.library.MCMT.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.MCMT.num_captured_vars "qiskit.circuit.library.MCMT.num_captured_vars") must be zero. + + ### num\_parameters @@ -137,6 +161,14 @@ python_api_name: qiskit.circuit.library.MCMT Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -218,20 +250,50 @@ python_api_name: qiskit.circuit.library.MCMT ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.MCMT.unit "qiskit.circuit.library.MCMT.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.MCMT.duration "qiskit.circuit.library.MCMT.duration") is specified in. ## Methods ### control - + Return the controlled version of the MCMT circuit. ### inverse - + Return the inverse MCMT circuit, which is itself. diff --git a/docs/api/qiskit/qiskit.circuit.library.MCMTVChain.mdx b/docs/api/qiskit/qiskit.circuit.library.MCMTVChain.mdx index 8c638a3856f..33b53d4dcf7 100644 --- a/docs/api/qiskit/qiskit.circuit.library.MCMTVChain.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.MCMTVChain.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MCMTVChain # MCMTVChain - + Bases: [`MCMT`](qiskit.circuit.library.MCMT "qiskit.circuit.library.generalized_gates.mcmt.MCMT") The MCMT implementation using the CCX V-chain. @@ -58,7 +58,7 @@ python_api_name: qiskit.circuit.library.MCMTVChain **Parameters** - * **gate** ([*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate") *| Callable\[\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*,* [*circuit.Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*,* [*circuit.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. + * **gate** ([*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate") *| Callable\[\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*,* [*circuit.Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")*,* [*circuit.Qubit*](circuit#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. @@ -72,7 +72,7 @@ python_api_name: qiskit.circuit.library.MCMTVChain ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -86,13 +86,13 @@ python_api_name: qiskit.circuit.library.MCMTVChain ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -106,12 +106,12 @@ python_api_name: qiskit.circuit.library.MCMTVChain ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -126,9 +126,9 @@ python_api_name: qiskit.circuit.library.MCMTVChain ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancilla\_qubits @@ -143,12 +143,36 @@ python_api_name: qiskit.circuit.library.MCMTVChain Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.MCMTVChain.num_input_vars "qiskit.circuit.library.MCMTVChain.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.MCMTVChain.num_captured_vars "qiskit.circuit.library.MCMTVChain.num_captured_vars") must be zero. + + ### num\_parameters @@ -161,6 +185,14 @@ python_api_name: qiskit.circuit.library.MCMTVChain Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -242,14 +274,44 @@ python_api_name: qiskit.circuit.library.MCMTVChain ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.MCMTVChain.unit "qiskit.circuit.library.MCMTVChain.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.MCMTVChain.duration "qiskit.circuit.library.MCMTVChain.duration") is specified in. ## Methods ### inverse - + Return the inverse MCMT circuit, which is itself. diff --git a/docs/api/qiskit/qiskit.circuit.library.MCPhaseGate.mdx b/docs/api/qiskit/qiskit.circuit.library.MCPhaseGate.mdx index ed62fdf45c7..bccefed3e87 100644 --- a/docs/api/qiskit/qiskit.circuit.library.MCPhaseGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.MCPhaseGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MCPhaseGate # MCPhaseGate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") Multi-controlled-Phase gate. @@ -86,7 +86,7 @@ python_api_name: qiskit.circuit.library.MCPhaseGate ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.MCPhaseGate.ctrl_state "qiskit.circuit.library.MCPhaseGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -173,7 +173,7 @@ python_api_name: qiskit.circuit.library.MCPhaseGate ### control - + Controlled version of this gate. **Parameters** @@ -194,8 +194,8 @@ python_api_name: qiskit.circuit.library.MCPhaseGate ### inverse - - Return inverted MCU1 gate ($MCU1(\lambda)^{\dagger} = MCU1(-\lambda)$) + + Return inverted MCPhase gate ($MCPhase(\lambda)^{\dagger} = MCPhase(-\lambda)$) diff --git a/docs/api/qiskit/qiskit.circuit.library.MCXGate.mdx b/docs/api/qiskit/qiskit.circuit.library.MCXGate.mdx index 9f6b1968aca..7cb401f7c52 100644 --- a/docs/api/qiskit/qiskit.circuit.library.MCXGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.MCXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MCXGate # MCXGate - + Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") The general, multi-controlled X gate. @@ -67,7 +67,7 @@ python_api_name: qiskit.circuit.library.MCXGate ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.MCXGate.ctrl_state "qiskit.circuit.library.MCXGate.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -160,14 +160,14 @@ python_api_name: qiskit.circuit.library.MCXGate ### control - + 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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **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*) – control state expressed as integer, string (e.g. `'110'`), or `None`. If `None`, use all 1s. * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. **Returns** @@ -181,7 +181,7 @@ python_api_name: qiskit.circuit.library.MCXGate ### get\_num\_ancilla\_qubits - + 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. @@ -193,7 +193,7 @@ python_api_name: qiskit.circuit.library.MCXGate ### inverse - + Invert this gate. The MCX is its own inverse. **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.MCXGrayCode.mdx b/docs/api/qiskit/qiskit.circuit.library.MCXGrayCode.mdx index d60cd5612df..8ce27c1fcdc 100644 --- a/docs/api/qiskit/qiskit.circuit.library.MCXGrayCode.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.MCXGrayCode.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MCXGrayCode # MCXGrayCode - + Bases: [`MCXGate`](qiskit.circuit.library.MCXGate "qiskit.circuit.library.standard_gates.x.MCXGate") Implement the multi-controlled X gate using the Gray code. @@ -67,7 +67,7 @@ python_api_name: qiskit.circuit.library.MCXGrayCode ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.MCXGrayCode.ctrl_state "qiskit.circuit.library.MCXGrayCode.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -160,7 +160,7 @@ python_api_name: qiskit.circuit.library.MCXGrayCode ### inverse - + Invert this gate. The MCX is its own inverse. **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.MCXRecursive.mdx b/docs/api/qiskit/qiskit.circuit.library.MCXRecursive.mdx index 51c52b51953..ce98e43d8d4 100644 --- a/docs/api/qiskit/qiskit.circuit.library.MCXRecursive.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.MCXRecursive.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MCXRecursive # MCXRecursive - + Bases: [`MCXGate`](qiskit.circuit.library.MCXGate "qiskit.circuit.library.standard_gates.x.MCXGate") Implement the multi-controlled X gate using recursion. @@ -67,7 +67,7 @@ python_api_name: qiskit.circuit.library.MCXRecursive ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.MCXRecursive.ctrl_state "qiskit.circuit.library.MCXRecursive.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -160,13 +160,13 @@ python_api_name: qiskit.circuit.library.MCXRecursive ### get\_num\_ancilla\_qubits - + Get the number of required ancilla qubits. ### inverse - + Invert this gate. The MCX is its own inverse. **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.MCXVChain.mdx b/docs/api/qiskit/qiskit.circuit.library.MCXVChain.mdx index ae64b3c32bf..2fe4ae1b65c 100644 --- a/docs/api/qiskit/qiskit.circuit.library.MCXVChain.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.MCXVChain.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MCXVChain # MCXVChain - + 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. @@ -65,7 +65,7 @@ python_api_name: qiskit.circuit.library.MCXVChain ### 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. + Return definition in terms of other basic gates. If the gate has open controls, as determined from [`ctrl_state`](#qiskit.circuit.library.MCXVChain.ctrl_state "qiskit.circuit.library.MCXVChain.ctrl_state"), the returned definition is conjugated with X without changing the internal `_definition`. ### duration @@ -158,13 +158,13 @@ python_api_name: qiskit.circuit.library.MCXVChain ### get\_num\_ancilla\_qubits - + Get the number of required ancilla qubits. ### inverse - + Invert this gate. The MCX is its own inverse. **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.MSGate.mdx b/docs/api/qiskit/qiskit.circuit.library.MSGate.mdx index e2c15b5bdb4..c635fc01e48 100644 --- a/docs/api/qiskit/qiskit.circuit.library.MSGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.MSGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.MSGate # MSGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") MSGate has been deprecated. Please use `GMS` in `qiskit.circuit.generalized_gates` instead. @@ -109,7 +109,7 @@ python_api_name: qiskit.circuit.library.MSGate ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit diff --git a/docs/api/qiskit/qiskit.circuit.library.NLocal.mdx b/docs/api/qiskit/qiskit.circuit.library.NLocal.mdx index e2d9715529f..8fafa72f505 100644 --- a/docs/api/qiskit/qiskit.circuit.library.NLocal.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.NLocal.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.NLocal # NLocal - + Bases: `BlueprintCircuit` The n-local circuit class. @@ -65,7 +65,7 @@ python_api_name: qiskit.circuit.library.NLocal ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -79,7 +79,7 @@ python_api_name: qiskit.circuit.library.NLocal ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -115,7 +115,7 @@ python_api_name: qiskit.circuit.library.NLocal ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -140,7 +140,7 @@ python_api_name: qiskit.circuit.library.NLocal ### instances - + ### layout @@ -155,9 +155,9 @@ python_api_name: qiskit.circuit.library.NLocal ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -166,12 +166,36 @@ python_api_name: qiskit.circuit.library.NLocal Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.NLocal.num_input_vars "qiskit.circuit.library.NLocal.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.NLocal.num_captured_vars "qiskit.circuit.library.NLocal.num_captured_vars") must be zero. + + ### num\_layers @@ -212,6 +236,14 @@ python_api_name: qiskit.circuit.library.NLocal The number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -285,13 +317,13 @@ python_api_name: qiskit.circuit.library.NLocal ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -314,11 +346,35 @@ python_api_name: qiskit.circuit.library.NLocal The blocks in the rotation layers. + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.NLocal.unit "qiskit.circuit.library.NLocal.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.NLocal.duration "qiskit.circuit.library.NLocal.duration") is specified in. + + ## Methods ### add\_layer - + Append another layer to the NLocal. **Parameters** @@ -342,7 +398,7 @@ python_api_name: qiskit.circuit.library.NLocal ### assign\_parameters - + 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"). @@ -362,7 +418,7 @@ python_api_name: qiskit.circuit.library.NLocal ### get\_entangler\_map - + 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. @@ -403,7 +459,7 @@ python_api_name: qiskit.circuit.library.NLocal ### get\_unentangled\_qubits - + Get the indices of unentangled qubits in a set. **Returns** @@ -417,7 +473,7 @@ python_api_name: qiskit.circuit.library.NLocal ### print\_settings - + Returns information about the setting. **Returns** diff --git a/docs/api/qiskit/qiskit.circuit.library.OR.mdx b/docs/api/qiskit/qiskit.circuit.library.OR.mdx index 7fa39c731c0..96ed3b7e159 100644 --- a/docs/api/qiskit/qiskit.circuit.library.OR.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.OR.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.OR # OR - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") A circuit implementing the logical OR operation on a number of qubits. @@ -36,7 +36,7 @@ python_api_name: qiskit.circuit.library.OR ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -50,13 +50,13 @@ python_api_name: qiskit.circuit.library.OR ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -70,12 +70,12 @@ python_api_name: qiskit.circuit.library.OR ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -90,9 +90,9 @@ python_api_name: qiskit.circuit.library.OR ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -101,12 +101,36 @@ python_api_name: qiskit.circuit.library.OR Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.OR.num_input_vars "qiskit.circuit.library.OR.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.OR.num_captured_vars "qiskit.circuit.library.OR.num_captured_vars") must be zero. + + ### num\_parameters @@ -119,6 +143,14 @@ python_api_name: qiskit.circuit.library.OR Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -200,7 +232,37 @@ python_api_name: qiskit.circuit.library.OR ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.OR.unit "qiskit.circuit.library.OR.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.OR.duration "qiskit.circuit.library.OR.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.PauliEvolutionGate.mdx b/docs/api/qiskit/qiskit.circuit.library.PauliEvolutionGate.mdx index 6c078089e88..4c4256d40ae 100644 --- a/docs/api/qiskit/qiskit.circuit.library.PauliEvolutionGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.PauliEvolutionGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PauliEvolutionGate # PauliEvolutionGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Time-evolution of an operator consisting of Paulis. @@ -156,7 +156,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### time @@ -179,7 +179,7 @@ $$ ### validate\_parameter - + Gate parameters should be int, float, or ParameterExpression **Return type** diff --git a/docs/api/qiskit/qiskit.circuit.library.PauliFeatureMap.mdx b/docs/api/qiskit/qiskit.circuit.library.PauliFeatureMap.mdx index dce247793ba..fe173465bd9 100644 --- a/docs/api/qiskit/qiskit.circuit.library.PauliFeatureMap.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.PauliFeatureMap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PauliFeatureMap # PauliFeatureMap - + Bases: [`NLocal`](qiskit.circuit.library.NLocal "qiskit.circuit.library.n_local.n_local.NLocal") The Pauli Expansion circuit. @@ -124,7 +124,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -138,7 +138,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -178,7 +178,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -203,7 +203,7 @@ $$ ### instances - + ### layout @@ -218,9 +218,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -229,12 +229,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.PauliFeatureMap.num_input_vars "qiskit.circuit.library.PauliFeatureMap.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.PauliFeatureMap.num_captured_vars "qiskit.circuit.library.PauliFeatureMap.num_captured_vars") must be zero. + + ### num\_layers @@ -265,6 +289,14 @@ $$ The number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -348,13 +380,13 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -377,17 +409,41 @@ $$ The blocks in the rotation layers. + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PauliFeatureMap.unit "qiskit.circuit.library.PauliFeatureMap.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PauliFeatureMap.duration "qiskit.circuit.library.PauliFeatureMap.duration") is specified in. + + ## Methods ### pauli\_block - + Get the Pauli block for the feature map circuit. ### pauli\_evolution - + Get the evolution block for the given pauli string. diff --git a/docs/api/qiskit/qiskit.circuit.library.PauliGate.mdx b/docs/api/qiskit/qiskit.circuit.library.PauliGate.mdx index de7d691ffd9..b9511cdc35e 100644 --- a/docs/api/qiskit/qiskit.circuit.library.PauliGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.PauliGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PauliGate # PauliGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") A multi-qubit Pauli gate. @@ -116,7 +116,7 @@ python_api_name: qiskit.circuit.library.PauliGate ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -129,13 +129,13 @@ python_api_name: qiskit.circuit.library.PauliGate ### inverse - + Return inverted pauli gate (itself). ### validate\_parameter - + Gate parameters should be int, float, or ParameterExpression diff --git a/docs/api/qiskit/qiskit.circuit.library.PauliTwoDesign.mdx b/docs/api/qiskit/qiskit.circuit.library.PauliTwoDesign.mdx index 18ac4b7b779..ca7dcc77928 100644 --- a/docs/api/qiskit/qiskit.circuit.library.PauliTwoDesign.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.PauliTwoDesign.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign # PauliTwoDesign - + Bases: [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.n_local.two_local.TwoLocal") The Pauli Two-Design ansatz. @@ -63,7 +63,7 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -77,7 +77,7 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -113,7 +113,7 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -138,7 +138,7 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign ### instances - + ### layout @@ -153,9 +153,9 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -164,12 +164,36 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.PauliTwoDesign.num_input_vars "qiskit.circuit.library.PauliTwoDesign.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.PauliTwoDesign.num_captured_vars "qiskit.circuit.library.PauliTwoDesign.num_captured_vars") must be zero. + + ### num\_layers @@ -204,6 +228,14 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign The number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -277,13 +309,13 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -305,5 +337,29 @@ python_api_name: qiskit.circuit.library.PauliTwoDesign The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PauliTwoDesign.unit "qiskit.circuit.library.PauliTwoDesign.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PauliTwoDesign.duration "qiskit.circuit.library.PauliTwoDesign.duration") is specified in. + diff --git a/docs/api/qiskit/qiskit.circuit.library.Permutation.mdx b/docs/api/qiskit/qiskit.circuit.library.Permutation.mdx index 719c5940c16..3b8aafb541f 100644 --- a/docs/api/qiskit/qiskit.circuit.library.Permutation.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.Permutation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.Permutation # Permutation - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") An n\_qubit circuit that permutes qubits. @@ -38,7 +38,7 @@ python_api_name: qiskit.circuit.library.Permutation ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -52,13 +52,13 @@ python_api_name: qiskit.circuit.library.Permutation ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -72,12 +72,12 @@ python_api_name: qiskit.circuit.library.Permutation ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -92,9 +92,9 @@ python_api_name: qiskit.circuit.library.Permutation ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -103,12 +103,36 @@ python_api_name: qiskit.circuit.library.Permutation Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.Permutation.num_input_vars "qiskit.circuit.library.Permutation.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.Permutation.num_captured_vars "qiskit.circuit.library.Permutation.num_captured_vars") must be zero. + + ### num\_parameters @@ -121,6 +145,14 @@ python_api_name: qiskit.circuit.library.Permutation Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -202,7 +234,37 @@ python_api_name: qiskit.circuit.library.Permutation ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.Permutation.unit "qiskit.circuit.library.Permutation.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.Permutation.duration "qiskit.circuit.library.Permutation.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.PermutationGate.mdx b/docs/api/qiskit/qiskit.circuit.library.PermutationGate.mdx index 79a571672ca..39e973a4f7b 100644 --- a/docs/api/qiskit/qiskit.circuit.library.PermutationGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.PermutationGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PermutationGate # PermutationGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") A gate that permutes qubits. @@ -119,7 +119,7 @@ python_api_name: qiskit.circuit.library.PermutationGate ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### pattern @@ -138,13 +138,13 @@ python_api_name: qiskit.circuit.library.PermutationGate ### inverse - + Returns the inverse of the permutation. ### validate\_parameter - + Parameter validation. diff --git a/docs/api/qiskit/qiskit.circuit.library.PhaseEstimation.mdx b/docs/api/qiskit/qiskit.circuit.library.PhaseEstimation.mdx index 61d50f2aa07..a769602306a 100644 --- a/docs/api/qiskit/qiskit.circuit.library.PhaseEstimation.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.PhaseEstimation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PhaseEstimation # PhaseEstimation - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Phase Estimation circuit. @@ -55,7 +55,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -69,13 +69,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -89,12 +89,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -109,9 +109,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -120,12 +120,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.PhaseEstimation.num_input_vars "qiskit.circuit.library.PhaseEstimation.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.PhaseEstimation.num_captured_vars "qiskit.circuit.library.PhaseEstimation.num_captured_vars") must be zero. + + ### num\_parameters @@ -138,6 +162,14 @@ $$ Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -219,7 +251,37 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PhaseEstimation.unit "qiskit.circuit.library.PhaseEstimation.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PhaseEstimation.duration "qiskit.circuit.library.PhaseEstimation.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.PhaseGate.mdx b/docs/api/qiskit/qiskit.circuit.library.PhaseGate.mdx index 7930a99492a..20ee162047f 100644 --- a/docs/api/qiskit/qiskit.circuit.library.PhaseGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.PhaseGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PhaseGate # PhaseGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Single-qubit rotation about the Z axis. @@ -149,7 +149,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -162,7 +162,7 @@ $$ ### control - + Return a (multi-)controlled-Phase gate. **Parameters** @@ -183,7 +183,7 @@ $$ ### inverse - + Return inverted Phase gate ($Phase(\lambda)^{\dagger} = Phase(-\lambda)$) **Parameters** @@ -201,8 +201,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.PhaseOracle.mdx b/docs/api/qiskit/qiskit.circuit.library.PhaseOracle.mdx index b116f8f4f05..051ea0ebab3 100644 --- a/docs/api/qiskit/qiskit.circuit.library.PhaseOracle.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.PhaseOracle.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PhaseOracle # PhaseOracle - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Phase Oracle. @@ -32,7 +32,7 @@ python_api_name: qiskit.circuit.library.PhaseOracle ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -46,13 +46,13 @@ python_api_name: qiskit.circuit.library.PhaseOracle ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -66,12 +66,12 @@ python_api_name: qiskit.circuit.library.PhaseOracle ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -86,9 +86,9 @@ python_api_name: qiskit.circuit.library.PhaseOracle ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -97,12 +97,36 @@ python_api_name: qiskit.circuit.library.PhaseOracle Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.PhaseOracle.num_input_vars "qiskit.circuit.library.PhaseOracle.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.PhaseOracle.num_captured_vars "qiskit.circuit.library.PhaseOracle.num_captured_vars") must be zero. + + ### num\_parameters @@ -115,6 +139,14 @@ python_api_name: qiskit.circuit.library.PhaseOracle Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -196,14 +228,44 @@ python_api_name: qiskit.circuit.library.PhaseOracle ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PhaseOracle.unit "qiskit.circuit.library.PhaseOracle.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PhaseOracle.duration "qiskit.circuit.library.PhaseOracle.duration") is specified in. ## Methods ### evaluate\_bitstring - + Evaluate the oracle on a bitstring. This evaluation is done classically without any quantum circuit. **Parameters** @@ -221,7 +283,7 @@ python_api_name: qiskit.circuit.library.PhaseOracle ### from\_dimacs\_file - + 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. diff --git a/docs/api/qiskit/qiskit.circuit.library.PiecewiseChebyshev.mdx b/docs/api/qiskit/qiskit.circuit.library.PiecewiseChebyshev.mdx index f146a65735d..a443bf96c88 100644 --- a/docs/api/qiskit/qiskit.circuit.library.PiecewiseChebyshev.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.PiecewiseChebyshev.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PiecewiseChebyshev # PiecewiseChebyshev - + Bases: `BlueprintCircuit` Piecewise Chebyshev approximation to an input function. @@ -57,7 +57,7 @@ python_api_name: qiskit.circuit.library.PiecewiseChebyshev ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### breakpoints @@ -81,7 +81,7 @@ python_api_name: qiskit.circuit.library.PiecewiseChebyshev ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -111,12 +111,12 @@ python_api_name: qiskit.circuit.library.PiecewiseChebyshev ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -131,9 +131,9 @@ python_api_name: qiskit.circuit.library.PiecewiseChebyshev ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -142,12 +142,36 @@ python_api_name: qiskit.circuit.library.PiecewiseChebyshev Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.PiecewiseChebyshev.num_input_vars "qiskit.circuit.library.PiecewiseChebyshev.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.PiecewiseChebyshev.num_captured_vars "qiskit.circuit.library.PiecewiseChebyshev.num_captured_vars") must be zero. + + ### num\_parameters @@ -168,6 +192,14 @@ python_api_name: qiskit.circuit.library.PiecewiseChebyshev The number of state qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -209,13 +241,37 @@ python_api_name: qiskit.circuit.library.PiecewiseChebyshev ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PiecewiseChebyshev.unit "qiskit.circuit.library.PiecewiseChebyshev.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PiecewiseChebyshev.duration "qiskit.circuit.library.PiecewiseChebyshev.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.PiecewiseLinearPauliRotations.mdx b/docs/api/qiskit/qiskit.circuit.library.PiecewiseLinearPauliRotations.mdx index 896cc19a495..d9299e4b295 100644 --- a/docs/api/qiskit/qiskit.circuit.library.PiecewiseLinearPauliRotations.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.PiecewiseLinearPauliRotations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PiecewiseLinearPauliRotations # PiecewiseLinearPauliRotations - + Bases: [`FunctionalPauliRotations`](qiskit.circuit.library.FunctionalPauliRotations "qiskit.circuit.library.arithmetic.functional_pauli_rotations.FunctionalPauliRotations") Piecewise-linearly-controlled Pauli rotations. @@ -40,7 +40,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### basis @@ -74,7 +74,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### contains\_zero\_breakpoint @@ -94,12 +94,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -134,9 +134,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancilla\_qubits @@ -155,12 +155,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.PiecewiseLinearPauliRotations.num_input_vars "qiskit.circuit.library.PiecewiseLinearPauliRotations.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.PiecewiseLinearPauliRotations.num_captured_vars "qiskit.circuit.library.PiecewiseLinearPauliRotations.num_captured_vars") must be zero. + + ### num\_parameters @@ -181,6 +205,14 @@ $$ The number of state qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### offsets @@ -216,13 +248,13 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### slopes @@ -233,11 +265,35 @@ $$ The function is linear in the intervals `[point_i, point_{i+1}]` where the last point implicitly is `2**(num_state_qubits + 1)`. + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PiecewiseLinearPauliRotations.unit "qiskit.circuit.library.PiecewiseLinearPauliRotations.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PiecewiseLinearPauliRotations.duration "qiskit.circuit.library.PiecewiseLinearPauliRotations.duration") is specified in. + + ## Methods ### evaluate - + Classically evaluate the piecewise linear rotation. **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.PiecewisePolynomialPauliRotations.mdx b/docs/api/qiskit/qiskit.circuit.library.PiecewisePolynomialPauliRotations.mdx index 7ae79bb96fc..2abec3a664f 100644 --- a/docs/api/qiskit/qiskit.circuit.library.PiecewisePolynomialPauliRotations.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.PiecewisePolynomialPauliRotations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PiecewisePolynomialPauliRotations # PiecewisePolynomialPauliRotations - + Bases: [`FunctionalPauliRotations`](qiskit.circuit.library.FunctionalPauliRotations "qiskit.circuit.library.arithmetic.functional_pauli_rotations.FunctionalPauliRotations") Piecewise-polynomially-controlled Pauli rotations. @@ -84,7 +84,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### basis @@ -122,7 +122,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### coeffs @@ -152,12 +152,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -182,9 +182,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancilla\_qubits @@ -203,12 +203,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.PiecewisePolynomialPauliRotations.num_input_vars "qiskit.circuit.library.PiecewisePolynomialPauliRotations.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.PiecewisePolynomialPauliRotations.num_captured_vars "qiskit.circuit.library.PiecewisePolynomialPauliRotations.num_captured_vars") must be zero. + + ### num\_parameters @@ -229,6 +253,14 @@ $$ The number of state qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -256,20 +288,44 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PiecewisePolynomialPauliRotations.unit "qiskit.circuit.library.PiecewisePolynomialPauliRotations.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PiecewisePolynomialPauliRotations.duration "qiskit.circuit.library.PiecewisePolynomialPauliRotations.duration") is specified in. ## Methods ### evaluate - + Classically evaluate the piecewise polynomial rotation. **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.PolynomialPauliRotations.mdx b/docs/api/qiskit/qiskit.circuit.library.PolynomialPauliRotations.mdx index 285dffa10a3..c3828c2e247 100644 --- a/docs/api/qiskit/qiskit.circuit.library.PolynomialPauliRotations.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.PolynomialPauliRotations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.PolynomialPauliRotations # PolynomialPauliRotations - + Bases: [`FunctionalPauliRotations`](qiskit.circuit.library.FunctionalPauliRotations "qiskit.circuit.library.arithmetic.functional_pauli_rotations.FunctionalPauliRotations") A circuit implementing polynomial Pauli rotations. @@ -48,7 +48,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### basis @@ -74,7 +74,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### coeffs @@ -112,12 +112,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -132,9 +132,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancilla\_qubits @@ -153,12 +153,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.PolynomialPauliRotations.num_input_vars "qiskit.circuit.library.PolynomialPauliRotations.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.PolynomialPauliRotations.num_captured_vars "qiskit.circuit.library.PolynomialPauliRotations.num_captured_vars") must be zero. + + ### num\_parameters @@ -179,6 +203,14 @@ $$ The number of state qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -206,13 +238,37 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.PolynomialPauliRotations.unit "qiskit.circuit.library.PolynomialPauliRotations.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.PolynomialPauliRotations.duration "qiskit.circuit.library.PolynomialPauliRotations.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.QAOAAnsatz.mdx b/docs/api/qiskit/qiskit.circuit.library.QAOAAnsatz.mdx index 42ed8bf6f42..8ccd6a1a6d9 100644 --- a/docs/api/qiskit/qiskit.circuit.library.QAOAAnsatz.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.QAOAAnsatz.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz # QAOAAnsatz - + Bases: [`EvolvedOperatorAnsatz`](qiskit.circuit.library.EvolvedOperatorAnsatz "qiskit.circuit.library.n_local.evolved_operator_ansatz.EvolvedOperatorAnsatz") A generalized QAOA quantum circuit with a support of custom initial states and mixers. @@ -33,7 +33,7 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -47,7 +47,7 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### cost\_operator @@ -111,7 +111,7 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -132,7 +132,7 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz ### instances - + ### layout @@ -147,9 +147,9 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### mixer\_operator @@ -172,12 +172,36 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.QAOAAnsatz.num_input_vars "qiskit.circuit.library.QAOAAnsatz.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.QAOAAnsatz.num_captured_vars "qiskit.circuit.library.QAOAAnsatz.num_captured_vars") must be zero. + + ### num\_layers @@ -212,6 +236,14 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -297,13 +329,13 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -321,5 +353,29 @@ python_api_name: qiskit.circuit.library.QAOAAnsatz The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.QAOAAnsatz.unit "qiskit.circuit.library.QAOAAnsatz.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.QAOAAnsatz.duration "qiskit.circuit.library.QAOAAnsatz.duration") is specified in. + diff --git a/docs/api/qiskit/qiskit.circuit.library.QFT.mdx b/docs/api/qiskit/qiskit.circuit.library.QFT.mdx index cb533a22082..ccf2e62387b 100644 --- a/docs/api/qiskit/qiskit.circuit.library.QFT.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.QFT.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.QFT # QFT - + Bases: `BlueprintCircuit` Quantum Fourier Transform Circuit. @@ -51,7 +51,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### approximation\_degree @@ -75,7 +75,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -95,7 +95,7 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### insert\_barriers @@ -110,7 +110,7 @@ $$ ### instances - + ### layout @@ -125,9 +125,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -136,12 +136,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.QFT.num_input_vars "qiskit.circuit.library.QFT.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.QFT.num_captured_vars "qiskit.circuit.library.QFT.num_captured_vars") must be zero. + + ### num\_parameters @@ -156,6 +180,14 @@ $$ The number of qubits in the circuit. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -183,20 +215,44 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.QFT.unit "qiskit.circuit.library.QFT.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.QFT.duration "qiskit.circuit.library.QFT.duration") is specified in. ## Methods ### inverse - + Invert this circuit. **Parameters** @@ -214,7 +270,7 @@ $$ ### is\_inverse - + Whether the inverse Fourier transform is implemented. **Returns** diff --git a/docs/api/qiskit/qiskit.circuit.library.QuadraticForm.mdx b/docs/api/qiskit/qiskit.circuit.library.QuadraticForm.mdx index ebc8e652be8..4d17acdf956 100644 --- a/docs/api/qiskit/qiskit.circuit.library.QuadraticForm.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.QuadraticForm.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.QuadraticForm # QuadraticForm - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Implements a quadratic form on binary variables encoded in qubit registers. @@ -57,7 +57,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -71,13 +71,13 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -91,12 +91,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -111,9 +111,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -122,12 +122,36 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.QuadraticForm.num_input_vars "qiskit.circuit.library.QuadraticForm.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.QuadraticForm.num_captured_vars "qiskit.circuit.library.QuadraticForm.num_captured_vars") must be zero. + + ### num\_parameters @@ -140,6 +164,14 @@ $$ Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -221,14 +253,44 @@ $$ ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.QuadraticForm.unit "qiskit.circuit.library.QuadraticForm.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.QuadraticForm.duration "qiskit.circuit.library.QuadraticForm.duration") is specified in. ## Methods ### required\_result\_qubits - + Get the number of required result qubits. **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.QuantumVolume.mdx b/docs/api/qiskit/qiskit.circuit.library.QuantumVolume.mdx index 411db9470ce..bca2b0f99c3 100644 --- a/docs/api/qiskit/qiskit.circuit.library.QuantumVolume.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.QuantumVolume.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.QuantumVolume # QuantumVolume - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") A quantum volume model circuit. @@ -37,13 +37,14 @@ python_api_name: qiskit.circuit.library.QuantumVolume * **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** ([*Generator*](https://numpy.org/doc/stable/reference/random/generator.html#numpy.random.Generator "(in NumPy v1.26)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| 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. + * **flatten** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `False` (the default), construct a circuit that contains a single instruction, which in turn has the actual volume structure. If `True`, construct the volume structure directly. ## Attributes ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -57,13 +58,13 @@ python_api_name: qiskit.circuit.library.QuantumVolume ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -77,12 +78,12 @@ python_api_name: qiskit.circuit.library.QuantumVolume ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -97,9 +98,9 @@ python_api_name: qiskit.circuit.library.QuantumVolume ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -108,12 +109,36 @@ python_api_name: qiskit.circuit.library.QuantumVolume Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.QuantumVolume.num_input_vars "qiskit.circuit.library.QuantumVolume.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.QuantumVolume.num_captured_vars "qiskit.circuit.library.QuantumVolume.num_captured_vars") must be zero. + + ### num\_parameters @@ -126,6 +151,14 @@ python_api_name: qiskit.circuit.library.QuantumVolume Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -207,7 +240,37 @@ python_api_name: qiskit.circuit.library.QuantumVolume ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.QuantumVolume.unit "qiskit.circuit.library.QuantumVolume.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.QuantumVolume.duration "qiskit.circuit.library.QuantumVolume.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.RC3XGate.mdx b/docs/api/qiskit/qiskit.circuit.library.RC3XGate.mdx index db45bef9169..824605c4a23 100644 --- a/docs/api/qiskit/qiskit.circuit.library.RC3XGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.RC3XGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RC3XGate # RC3XGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The simplified 3-controlled Toffoli gate. @@ -109,7 +109,7 @@ python_api_name: qiskit.circuit.library.RC3XGate ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit diff --git a/docs/api/qiskit/qiskit.circuit.library.RCCXGate.mdx b/docs/api/qiskit/qiskit.circuit.library.RCCXGate.mdx index bc5db7fbb02..0b517c029b2 100644 --- a/docs/api/qiskit/qiskit.circuit.library.RCCXGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.RCCXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RCCXGate # RCCXGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The simplified Toffoli gate, also referred to as Margolus gate. @@ -109,7 +109,7 @@ python_api_name: qiskit.circuit.library.RCCXGate ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit diff --git a/docs/api/qiskit/qiskit.circuit.library.RGQFTMultiplier.mdx b/docs/api/qiskit/qiskit.circuit.library.RGQFTMultiplier.mdx index 1f9e1320017..845759548d6 100644 --- a/docs/api/qiskit/qiskit.circuit.library.RGQFTMultiplier.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.RGQFTMultiplier.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RGQFTMultiplier # RGQFTMultiplier - + Bases: `Multiplier` A QFT multiplication circuit to store product of two input registers out-of-place. @@ -45,7 +45,7 @@ python_api_name: qiskit.circuit.library.RGQFTMultiplier ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -59,13 +59,13 @@ python_api_name: qiskit.circuit.library.RGQFTMultiplier ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -79,12 +79,12 @@ python_api_name: qiskit.circuit.library.RGQFTMultiplier ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -99,9 +99,9 @@ python_api_name: qiskit.circuit.library.RGQFTMultiplier ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -110,12 +110,36 @@ python_api_name: qiskit.circuit.library.RGQFTMultiplier Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.RGQFTMultiplier.num_input_vars "qiskit.circuit.library.RGQFTMultiplier.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.RGQFTMultiplier.num_captured_vars "qiskit.circuit.library.RGQFTMultiplier.num_captured_vars") must be zero. + + ### num\_parameters @@ -148,6 +172,14 @@ python_api_name: qiskit.circuit.library.RGQFTMultiplier The number of state qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -229,7 +261,37 @@ python_api_name: qiskit.circuit.library.RGQFTMultiplier ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.RGQFTMultiplier.unit "qiskit.circuit.library.RGQFTMultiplier.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.RGQFTMultiplier.duration "qiskit.circuit.library.RGQFTMultiplier.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.RGate.mdx b/docs/api/qiskit/qiskit.circuit.library.RGate.mdx index 690ebc7366f..e06d41de605 100644 --- a/docs/api/qiskit/qiskit.circuit.library.RGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.RGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RGate # RGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Rotation θ around the cos(φ)x + sin(φ)y axis. @@ -125,7 +125,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -138,7 +138,7 @@ $$ ### inverse - + Invert this gate as: $r(θ, φ)^dagger = r(-θ, φ)$ **Parameters** @@ -156,8 +156,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.RVGate.mdx b/docs/api/qiskit/qiskit.circuit.library.RVGate.mdx index 2e4714154da..7e1fa3607a1 100644 --- a/docs/api/qiskit/qiskit.circuit.library.RVGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.RVGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RVGate # RVGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Rotation around arbitrary rotation axis $\vec{v}$ where $\|\vec{v}\|_2$ is angle of rotation in radians. @@ -137,7 +137,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -150,13 +150,13 @@ $$ ### inverse - + Invert this gate. ### to\_matrix - + Return a numpy.array for the R(v) gate. diff --git a/docs/api/qiskit/qiskit.circuit.library.RXGate.mdx b/docs/api/qiskit/qiskit.circuit.library.RXGate.mdx index 3e1b31de5e5..904239c5809 100644 --- a/docs/api/qiskit/qiskit.circuit.library.RXGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.RXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RXGate # RXGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Single-qubit rotation about the X axis. @@ -125,7 +125,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -138,7 +138,7 @@ $$ ### control - + Return a (multi-)controlled-RX gate. **Parameters** @@ -159,7 +159,7 @@ $$ ### inverse - + Return inverted RX gate. $RX(\lambda)^{\dagger} = RX(-\lambda)$ @@ -179,8 +179,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](#qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](#qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.RXXGate.mdx b/docs/api/qiskit/qiskit.circuit.library.RXXGate.mdx index 52ba90ce2f3..60612b4d371 100644 --- a/docs/api/qiskit/qiskit.circuit.library.RXXGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.RXXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RXXGate # RXXGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") A parametric 2-qubit $X \otimes X$ interaction (rotation about XX). @@ -151,7 +151,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -164,7 +164,7 @@ $$ ### inverse - + Return inverse RXX gate (i.e. with the negative rotation angle). **Parameters** @@ -182,8 +182,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.RYGate.mdx b/docs/api/qiskit/qiskit.circuit.library.RYGate.mdx index 074539986d2..bf9fa6c7df1 100644 --- a/docs/api/qiskit/qiskit.circuit.library.RYGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.RYGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RYGate # RYGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Single-qubit rotation about the Y axis. @@ -125,7 +125,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -138,7 +138,7 @@ $$ ### control - + Return a (multi-)controlled-RY gate. **Parameters** @@ -159,7 +159,7 @@ $$ ### inverse - + Return inverse RY gate. $RY(\lambda)^{\dagger} = RY(-\lambda)$ @@ -179,8 +179,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.RYYGate.mdx b/docs/api/qiskit/qiskit.circuit.library.RYYGate.mdx index 82e61121d2c..2eb5d10b0fd 100644 --- a/docs/api/qiskit/qiskit.circuit.library.RYYGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.RYYGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RYYGate # RYYGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") A parametric 2-qubit $Y \otimes Y$ interaction (rotation about YY). @@ -151,7 +151,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -164,7 +164,7 @@ $$ ### inverse - + Return inverse RYY gate (i.e. with the negative rotation angle). **Parameters** @@ -182,8 +182,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.RZGate.mdx b/docs/api/qiskit/qiskit.circuit.library.RZGate.mdx index 7e892e1da0c..99803f950bf 100644 --- a/docs/api/qiskit/qiskit.circuit.library.RZGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.RZGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RZGate # RZGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Single-qubit rotation about the Z axis. @@ -135,7 +135,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -148,7 +148,7 @@ $$ ### control - + Return a (multi-)controlled-RZ gate. **Parameters** @@ -169,7 +169,7 @@ $$ ### inverse - + Return inverted RZ gate $RZ(\lambda)^{\dagger} = RZ(-\lambda)$ @@ -189,8 +189,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.RZXGate.mdx b/docs/api/qiskit/qiskit.circuit.library.RZXGate.mdx index b796bbad54e..1aa2c6dd417 100644 --- a/docs/api/qiskit/qiskit.circuit.library.RZXGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.RZXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RZXGate # RZXGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") A parametric 2-qubit $Z \otimes X$ interaction (rotation about ZX). @@ -191,7 +191,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -204,7 +204,7 @@ $$ ### inverse - + Return inverse RZX gate (i.e. with the negative rotation angle). **Parameters** @@ -222,8 +222,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.RZZGate.mdx b/docs/api/qiskit/qiskit.circuit.library.RZZGate.mdx index c008fa72ff8..d6023d55019 100644 --- a/docs/api/qiskit/qiskit.circuit.library.RZZGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.RZZGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RZZGate # RZZGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") A parametric 2-qubit $Z \otimes Z$ interaction (rotation about ZZ). @@ -163,7 +163,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -176,7 +176,7 @@ $$ ### inverse - + Return inverse RZZ gate (i.e. with the negative rotation angle). **Parameters** @@ -194,8 +194,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.RealAmplitudes.mdx b/docs/api/qiskit/qiskit.circuit.library.RealAmplitudes.mdx index 7cfe3560879..6049014bccb 100644 --- a/docs/api/qiskit/qiskit.circuit.library.RealAmplitudes.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.RealAmplitudes.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.RealAmplitudes # RealAmplitudes - + Bases: [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.n_local.two_local.TwoLocal") The real-amplitudes 2-local circuit. @@ -117,7 +117,7 @@ python_api_name: qiskit.circuit.library.RealAmplitudes ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -131,7 +131,7 @@ python_api_name: qiskit.circuit.library.RealAmplitudes ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -167,7 +167,7 @@ python_api_name: qiskit.circuit.library.RealAmplitudes ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -192,7 +192,7 @@ python_api_name: qiskit.circuit.library.RealAmplitudes ### instances - + ### layout @@ -207,9 +207,9 @@ python_api_name: qiskit.circuit.library.RealAmplitudes ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -218,12 +218,36 @@ python_api_name: qiskit.circuit.library.RealAmplitudes Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.RealAmplitudes.num_input_vars "qiskit.circuit.library.RealAmplitudes.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.RealAmplitudes.num_captured_vars "qiskit.circuit.library.RealAmplitudes.num_captured_vars") must be zero. + + ### num\_layers @@ -264,6 +288,14 @@ python_api_name: qiskit.circuit.library.RealAmplitudes The number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -337,13 +369,13 @@ python_api_name: qiskit.circuit.library.RealAmplitudes ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -365,5 +397,29 @@ python_api_name: qiskit.circuit.library.RealAmplitudes The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.RealAmplitudes.unit "qiskit.circuit.library.RealAmplitudes.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.RealAmplitudes.duration "qiskit.circuit.library.RealAmplitudes.duration") is specified in. + diff --git a/docs/api/qiskit/qiskit.circuit.library.SGate.mdx b/docs/api/qiskit/qiskit.circuit.library.SGate.mdx index 209f5cab960..c8f5a159b20 100644 --- a/docs/api/qiskit/qiskit.circuit.library.SGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.SGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.SGate # SGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") Single qubit S gate (Z\*\*0.5). @@ -128,7 +128,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -141,7 +141,7 @@ $$ ### inverse - + Return inverse of S (SdgGate). **Parameters** @@ -159,8 +159,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.SXGate.mdx b/docs/api/qiskit/qiskit.circuit.library.SXGate.mdx index af11ca417dc..81ee5e2a648 100644 --- a/docs/api/qiskit/qiskit.circuit.library.SXGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.SXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.SXGate # SXGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The single-qubit Sqrt(X) gate ($\sqrt{X}$). @@ -134,7 +134,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -147,7 +147,7 @@ $$ ### control - + Return a (multi-)controlled-SX gate. One control returns a CSX gate. @@ -170,7 +170,7 @@ $$ ### inverse - + Return inverse SX gate (i.e. SXdg). **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.SXdgGate.mdx b/docs/api/qiskit/qiskit.circuit.library.SXdgGate.mdx index aeb6263c150..f556abf081d 100644 --- a/docs/api/qiskit/qiskit.circuit.library.SXdgGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.SXdgGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.SXdgGate # SXdgGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The inverse single-qubit Sqrt(X) gate. @@ -124,7 +124,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -137,7 +137,7 @@ $$ ### inverse - + Return inverse SXdg gate (i.e. SX). **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.SdgGate.mdx b/docs/api/qiskit/qiskit.circuit.library.SdgGate.mdx index 817b767d2f7..f92ad800cab 100644 --- a/docs/api/qiskit/qiskit.circuit.library.SdgGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.SdgGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.SdgGate # SdgGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") Single qubit S-adjoint gate (\~Z\*\*0.5). @@ -128,7 +128,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -141,7 +141,7 @@ $$ ### inverse - + Return inverse of Sdg (SGate). **Parameters** @@ -159,8 +159,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.StatePreparation.mdx b/docs/api/qiskit/qiskit.circuit.library.StatePreparation.mdx index cf229907413..3c2f28c5b14 100644 --- a/docs/api/qiskit/qiskit.circuit.library.StatePreparation.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.StatePreparation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.StatePreparation # StatePreparation - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Complex amplitude state preparation. @@ -128,7 +128,7 @@ python_api_name: qiskit.circuit.library.StatePreparation ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -141,7 +141,7 @@ python_api_name: qiskit.circuit.library.StatePreparation ### broadcast\_arguments - + 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: @@ -190,13 +190,13 @@ python_api_name: qiskit.circuit.library.StatePreparation ### inverse - + Return inverted StatePreparation ### validate\_parameter - + StatePreparation instruction parameter can be str, int, float, and complex. diff --git a/docs/api/qiskit/qiskit.circuit.library.SwapGate.mdx b/docs/api/qiskit/qiskit.circuit.library.SwapGate.mdx index b7d10d9eeb2..be7c74c8e0b 100644 --- a/docs/api/qiskit/qiskit.circuit.library.SwapGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.SwapGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.SwapGate # SwapGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The SWAP gate. @@ -133,7 +133,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -146,7 +146,7 @@ $$ ### control - + Return a (multi-)controlled-SWAP gate. One control returns a CSWAP (Fredkin) gate. @@ -169,7 +169,7 @@ $$ ### inverse - + Return inverse Swap gate (itself). **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.TGate.mdx b/docs/api/qiskit/qiskit.circuit.library.TGate.mdx index 2743bc72de7..715c8bee6b1 100644 --- a/docs/api/qiskit/qiskit.circuit.library.TGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.TGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.TGate # TGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") Single qubit T gate (Z\*\*0.25). @@ -128,7 +128,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -141,7 +141,7 @@ $$ ### inverse - + Return inverse T gate (i.e. Tdg). **Parameters** @@ -159,8 +159,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.TdgGate.mdx b/docs/api/qiskit/qiskit.circuit.library.TdgGate.mdx index 196e9c13842..e53fcab4c55 100644 --- a/docs/api/qiskit/qiskit.circuit.library.TdgGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.TdgGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.TdgGate # TdgGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") Single qubit T-adjoint gate (\~Z\*\*0.25). @@ -128,7 +128,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -141,7 +141,7 @@ $$ ### inverse - + Return inverse Tdg gate (i.e. T). **Parameters** @@ -159,8 +159,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.TwoLocal.mdx b/docs/api/qiskit/qiskit.circuit.library.TwoLocal.mdx index 057dfe392e9..4c91280b4c3 100644 --- a/docs/api/qiskit/qiskit.circuit.library.TwoLocal.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.TwoLocal.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.TwoLocal # TwoLocal - + Bases: [`NLocal`](qiskit.circuit.library.NLocal "qiskit.circuit.library.n_local.n_local.NLocal") The two-local circuit. @@ -129,7 +129,7 @@ python_api_name: qiskit.circuit.library.TwoLocal ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -143,7 +143,7 @@ python_api_name: qiskit.circuit.library.TwoLocal ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -179,7 +179,7 @@ python_api_name: qiskit.circuit.library.TwoLocal ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -204,7 +204,7 @@ python_api_name: qiskit.circuit.library.TwoLocal ### instances - + ### layout @@ -219,9 +219,9 @@ python_api_name: qiskit.circuit.library.TwoLocal ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -230,12 +230,36 @@ python_api_name: qiskit.circuit.library.TwoLocal Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.TwoLocal.num_input_vars "qiskit.circuit.library.TwoLocal.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.TwoLocal.num_captured_vars "qiskit.circuit.library.TwoLocal.num_captured_vars") must be zero. + + ### num\_layers @@ -276,6 +300,14 @@ python_api_name: qiskit.circuit.library.TwoLocal The number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -349,13 +381,13 @@ python_api_name: qiskit.circuit.library.TwoLocal ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -378,11 +410,35 @@ python_api_name: qiskit.circuit.library.TwoLocal The blocks in the rotation layers. + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.TwoLocal.unit "qiskit.circuit.library.TwoLocal.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.TwoLocal.duration "qiskit.circuit.library.TwoLocal.duration") is specified in. + + ## Methods ### get\_entangler\_map - + Overloading to handle the special case of 1 qubit where the entanglement are ignored. **Return type** diff --git a/docs/api/qiskit/qiskit.circuit.library.U1Gate.mdx b/docs/api/qiskit/qiskit.circuit.library.U1Gate.mdx index 3450710eb5e..b89e7dfeb4c 100644 --- a/docs/api/qiskit/qiskit.circuit.library.U1Gate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.U1Gate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.U1Gate # U1Gate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Single-qubit rotation about the Z axis. @@ -162,7 +162,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -175,7 +175,7 @@ $$ ### control - + Return a (multi-)controlled-U1 gate. **Parameters** @@ -196,7 +196,7 @@ $$ ### inverse - + Return inverted U1 gate ($U1(\lambda)^{\dagger} = U1(-\lambda))$ **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.U2Gate.mdx b/docs/api/qiskit/qiskit.circuit.library.U2Gate.mdx index 48ca1bf4e0d..aa9f85d5af6 100644 --- a/docs/api/qiskit/qiskit.circuit.library.U2Gate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.U2Gate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.U2Gate # U2Gate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Single-qubit rotation about the X+Z axis. @@ -161,7 +161,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -174,7 +174,7 @@ $$ ### inverse - + Return inverted U2 gate. $U2(\phi, \lambda)^{\dagger} =U2(-\lambda-\pi, -\phi+\pi))$ diff --git a/docs/api/qiskit/qiskit.circuit.library.U3Gate.mdx b/docs/api/qiskit/qiskit.circuit.library.U3Gate.mdx index a75a806b8d1..36099cb09bd 100644 --- a/docs/api/qiskit/qiskit.circuit.library.U3Gate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.U3Gate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.U3Gate # U3Gate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Generic single-qubit rotation gate with 3 Euler angles. @@ -156,7 +156,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -169,7 +169,7 @@ $$ ### control - + Return a (multi-)controlled-U3 gate. **Parameters** @@ -190,7 +190,7 @@ $$ ### inverse - + Return inverted U3 gate. $U3(\theta,\phi,\lambda)^{\dagger} =U3(-\theta,-\lambda,-\phi))$ diff --git a/docs/api/qiskit/qiskit.circuit.library.UCGate.mdx b/docs/api/qiskit/qiskit.circuit.library.UCGate.mdx index 0c36d82547b..70ccc0702db 100644 --- a/docs/api/qiskit/qiskit.circuit.library.UCGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.UCGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UCGate # UCGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Uniformly controlled gate (also called multiplexed gate). @@ -131,7 +131,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -144,7 +144,7 @@ $$ ### 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. @@ -156,7 +156,7 @@ $$ ### validate\_parameter - + Uniformly controlled gate parameter has to be an ndarray. diff --git a/docs/api/qiskit/qiskit.circuit.library.UCPauliRotGate.mdx b/docs/api/qiskit/qiskit.circuit.library.UCPauliRotGate.mdx index ea9814aa122..41cf07c52d6 100644 --- a/docs/api/qiskit/qiskit.circuit.library.UCPauliRotGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.UCPauliRotGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UCPauliRotGate # UCPauliRotGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Uniformly controlled Pauli rotations. @@ -108,7 +108,7 @@ python_api_name: qiskit.circuit.library.UCPauliRotGate ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit diff --git a/docs/api/qiskit/qiskit.circuit.library.UCRXGate.mdx b/docs/api/qiskit/qiskit.circuit.library.UCRXGate.mdx index 55446bc4e0e..9749f619b74 100644 --- a/docs/api/qiskit/qiskit.circuit.library.UCRXGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.UCRXGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UCRXGate # UCRXGate - + Bases: [`UCPauliRotGate`](qiskit.circuit.library.UCPauliRotGate "qiskit.circuit.library.generalized_gates.uc_pauli_rot.UCPauliRotGate") Uniformly controlled Pauli-X rotations. @@ -107,7 +107,7 @@ python_api_name: qiskit.circuit.library.UCRXGate ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit diff --git a/docs/api/qiskit/qiskit.circuit.library.UCRYGate.mdx b/docs/api/qiskit/qiskit.circuit.library.UCRYGate.mdx index 465f6729c49..5a81ccdeeae 100644 --- a/docs/api/qiskit/qiskit.circuit.library.UCRYGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.UCRYGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UCRYGate # UCRYGate - + Bases: [`UCPauliRotGate`](qiskit.circuit.library.UCPauliRotGate "qiskit.circuit.library.generalized_gates.uc_pauli_rot.UCPauliRotGate") Uniformly controlled Pauli-Y rotations. @@ -107,7 +107,7 @@ python_api_name: qiskit.circuit.library.UCRYGate ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit diff --git a/docs/api/qiskit/qiskit.circuit.library.UCRZGate.mdx b/docs/api/qiskit/qiskit.circuit.library.UCRZGate.mdx index de8d111541d..e2992f0e4a1 100644 --- a/docs/api/qiskit/qiskit.circuit.library.UCRZGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.UCRZGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UCRZGate # UCRZGate - + Bases: [`UCPauliRotGate`](qiskit.circuit.library.UCPauliRotGate "qiskit.circuit.library.generalized_gates.uc_pauli_rot.UCPauliRotGate") Uniformly controlled Pauli-Z rotations. @@ -107,7 +107,7 @@ python_api_name: qiskit.circuit.library.UCRZGate ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit diff --git a/docs/api/qiskit/qiskit.circuit.library.UGate.mdx b/docs/api/qiskit/qiskit.circuit.library.UGate.mdx index a6b4955c065..2d69f37898e 100644 --- a/docs/api/qiskit/qiskit.circuit.library.UGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.UGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UGate # UGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Generic single-qubit rotation gate with 3 Euler angles. @@ -139,7 +139,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -152,7 +152,7 @@ $$ ### control - + Return a (multi-)controlled-U gate. **Parameters** @@ -173,7 +173,7 @@ $$ ### inverse - + Return inverted U gate. $U(\theta,\phi,\lambda)^{\dagger} =U(-\theta,-\lambda,-\phi))$ diff --git a/docs/api/qiskit/qiskit.circuit.library.UnitaryGate.mdx b/docs/api/qiskit/qiskit.circuit.library.UnitaryGate.mdx index aae20f1caaf..49677cfb70e 100644 --- a/docs/api/qiskit/qiskit.circuit.library.UnitaryGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.UnitaryGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UnitaryGate # UnitaryGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") Class quantum gates specified by a unitary matrix. @@ -38,6 +38,7 @@ python_api_name: qiskit.circuit.library.UnitaryGate * **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. + * **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – If given, the number of qubits in the matrix. If not given, it is inferred. **Raises** @@ -131,7 +132,7 @@ python_api_name: qiskit.circuit.library.UnitaryGate ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -144,19 +145,19 @@ python_api_name: qiskit.circuit.library.UnitaryGate ### adjoint - + Return the adjoint of the unitary. ### conjugate - + Return the conjugate of the unitary. ### control - + Return controlled version of gate. **Parameters** @@ -177,19 +178,19 @@ python_api_name: qiskit.circuit.library.UnitaryGate ### inverse - + Return the adjoint of the unitary. ### transpose - + Return the transpose of the unitary. ### validate\_parameter - + Unitary gate parameter has to be an ndarray. diff --git a/docs/api/qiskit/qiskit.circuit.library.UnitaryOverlap.mdx b/docs/api/qiskit/qiskit.circuit.library.UnitaryOverlap.mdx index dce005d6d91..6c7260400e5 100644 --- a/docs/api/qiskit/qiskit.circuit.library.UnitaryOverlap.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.UnitaryOverlap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.UnitaryOverlap # UnitaryOverlap - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") Circuit that returns the overlap between two unitaries $U_2^{\dag} U_1$. @@ -17,11 +17,9 @@ python_api_name: qiskit.circuit.library.UnitaryOverlap This circuit is usually employed in computing the fidelity: - ```python - .. math:: - - \left|\langle 0| U_2^{\dag} U_1|0\rangle\right|^{2} - ``` +$$ +\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|$. @@ -65,7 +63,7 @@ python_api_name: qiskit.circuit.library.UnitaryOverlap ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -79,13 +77,13 @@ python_api_name: qiskit.circuit.library.UnitaryOverlap ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -99,12 +97,12 @@ python_api_name: qiskit.circuit.library.UnitaryOverlap ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -119,9 +117,9 @@ python_api_name: qiskit.circuit.library.UnitaryOverlap ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -130,12 +128,36 @@ python_api_name: qiskit.circuit.library.UnitaryOverlap Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.UnitaryOverlap.num_input_vars "qiskit.circuit.library.UnitaryOverlap.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.UnitaryOverlap.num_captured_vars "qiskit.circuit.library.UnitaryOverlap.num_captured_vars") must be zero. + + ### num\_parameters @@ -148,6 +170,14 @@ python_api_name: qiskit.circuit.library.UnitaryOverlap Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -229,7 +259,37 @@ python_api_name: qiskit.circuit.library.UnitaryOverlap ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.UnitaryOverlap.unit "qiskit.circuit.library.UnitaryOverlap.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.UnitaryOverlap.duration "qiskit.circuit.library.UnitaryOverlap.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.VBERippleCarryAdder.mdx b/docs/api/qiskit/qiskit.circuit.library.VBERippleCarryAdder.mdx index a7de53fb7c9..1f9b96b88b4 100644 --- a/docs/api/qiskit/qiskit.circuit.library.VBERippleCarryAdder.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.VBERippleCarryAdder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.VBERippleCarryAdder # VBERippleCarryAdder - + Bases: `Adder` The VBE ripple carry adder \[1]. @@ -54,7 +54,7 @@ python_api_name: qiskit.circuit.library.VBERippleCarryAdder ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -68,13 +68,13 @@ python_api_name: qiskit.circuit.library.VBERippleCarryAdder ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -88,12 +88,12 @@ python_api_name: qiskit.circuit.library.VBERippleCarryAdder ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -108,9 +108,9 @@ python_api_name: qiskit.circuit.library.VBERippleCarryAdder ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -119,12 +119,36 @@ python_api_name: qiskit.circuit.library.VBERippleCarryAdder Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.VBERippleCarryAdder.num_input_vars "qiskit.circuit.library.VBERippleCarryAdder.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.VBERippleCarryAdder.num_captured_vars "qiskit.circuit.library.VBERippleCarryAdder.num_captured_vars") must be zero. + + ### num\_parameters @@ -147,6 +171,14 @@ python_api_name: qiskit.circuit.library.VBERippleCarryAdder The number of state qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -228,7 +260,37 @@ python_api_name: qiskit.circuit.library.VBERippleCarryAdder ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.VBERippleCarryAdder.unit "qiskit.circuit.library.VBERippleCarryAdder.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.VBERippleCarryAdder.duration "qiskit.circuit.library.VBERippleCarryAdder.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.WeightedAdder.mdx b/docs/api/qiskit/qiskit.circuit.library.WeightedAdder.mdx index 329f2ebb523..9d8f47929a7 100644 --- a/docs/api/qiskit/qiskit.circuit.library.WeightedAdder.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.WeightedAdder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.WeightedAdder # WeightedAdder - + Bases: `BlueprintCircuit` A circuit to compute the weighted sum of qubit registers. @@ -67,7 +67,7 @@ $$ ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -81,7 +81,7 @@ $$ ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -91,12 +91,12 @@ $$ ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -111,9 +111,9 @@ $$ ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -122,6 +122,14 @@ $$ Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.WeightedAdder.num_input_vars "qiskit.circuit.library.WeightedAdder.num_input_vars") must be zero. + + ### num\_carry\_qubits @@ -152,6 +160,22 @@ $$ The number of additional control qubits required (0 or 1). + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.WeightedAdder.num_captured_vars "qiskit.circuit.library.WeightedAdder.num_captured_vars") must be zero. + + ### num\_parameters @@ -182,6 +206,14 @@ $$ The number of qubits needed to represent the weighted sum of the qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -209,13 +241,13 @@ $$ ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### weights @@ -227,5 +259,29 @@ $$ The weight for the qubit states. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.WeightedAdder.unit "qiskit.circuit.library.WeightedAdder.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.WeightedAdder.duration "qiskit.circuit.library.WeightedAdder.duration") is specified in. + diff --git a/docs/api/qiskit/qiskit.circuit.library.XGate.mdx b/docs/api/qiskit/qiskit.circuit.library.XGate.mdx index b683fcfe6af..5ebf5dce11d 100644 --- a/docs/api/qiskit/qiskit.circuit.library.XGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.XGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.XGate # XGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The single-qubit Pauli-X gate ($\sigma_x$). @@ -143,7 +143,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -156,7 +156,7 @@ $$ ### control - + Return a (multi-)controlled-X gate. One control returns a CX gate. Two controls returns a CCX gate. @@ -165,7 +165,7 @@ $$ * **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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **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*) – control state expressed as integer, string (e.g. `'110'`), or `None`. If `None`, use all 1s. * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. **Returns** @@ -179,7 +179,7 @@ $$ ### inverse - + Return inverted X gate (itself). **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.XOR.mdx b/docs/api/qiskit/qiskit.circuit.library.XOR.mdx index e2b221e3791..028519dc82c 100644 --- a/docs/api/qiskit/qiskit.circuit.library.XOR.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.XOR.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.XOR # XOR - + Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") An n\_qubit circuit for bitwise xor-ing the input with some integer `amount`. @@ -38,7 +38,7 @@ python_api_name: qiskit.circuit.library.XOR ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -52,13 +52,13 @@ python_api_name: qiskit.circuit.library.XOR ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -72,12 +72,12 @@ python_api_name: qiskit.circuit.library.XOR ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -92,9 +92,9 @@ python_api_name: qiskit.circuit.library.XOR ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -103,12 +103,36 @@ python_api_name: qiskit.circuit.library.XOR Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.XOR.num_input_vars "qiskit.circuit.library.XOR.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.XOR.num_captured_vars "qiskit.circuit.library.XOR.num_captured_vars") must be zero. + + ### num\_parameters @@ -121,6 +145,14 @@ python_api_name: qiskit.circuit.library.XOR Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -202,7 +234,37 @@ python_api_name: qiskit.circuit.library.XOR ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. + + + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.XOR.unit "qiskit.circuit.library.XOR.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.XOR.duration "qiskit.circuit.library.XOR.duration") is specified in. diff --git a/docs/api/qiskit/qiskit.circuit.library.XXMinusYYGate.mdx b/docs/api/qiskit/qiskit.circuit.library.XXMinusYYGate.mdx index 979893888fd..ecfe1cbbdca 100644 --- a/docs/api/qiskit/qiskit.circuit.library.XXMinusYYGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.XXMinusYYGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.XXMinusYYGate # XXMinusYYGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") XX-YY interaction gate. @@ -161,7 +161,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -174,7 +174,7 @@ $$ ### inverse - + Inverse gate. **Parameters** @@ -192,8 +192,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.XXPlusYYGate.mdx b/docs/api/qiskit/qiskit.circuit.library.XXPlusYYGate.mdx index 208478c0c56..9c64498ed4a 100644 --- a/docs/api/qiskit/qiskit.circuit.library.XXPlusYYGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.XXPlusYYGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.XXPlusYYGate # XXPlusYYGate - + Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") XX+YY interaction gate. @@ -161,7 +161,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -174,7 +174,7 @@ $$ ### inverse - + Return inverse XX+YY gate (i.e. with the negative rotation angle and same phase angle). **Parameters** @@ -192,8 +192,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.YGate.mdx b/docs/api/qiskit/qiskit.circuit.library.YGate.mdx index 32163acfe8b..85c4494c303 100644 --- a/docs/api/qiskit/qiskit.circuit.library.YGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.YGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.YGate # YGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The single-qubit Pauli-Y gate ($\sigma_y$). @@ -143,7 +143,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -156,7 +156,7 @@ $$ ### control - + Return a (multi-)controlled-Y gate. One control returns a CY gate. @@ -165,7 +165,7 @@ $$ * **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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **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*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. **Returns** @@ -179,7 +179,7 @@ $$ ### inverse - + Return inverted Y gate ($Y^{\dagger} = Y$) **Parameters** diff --git a/docs/api/qiskit/qiskit.circuit.library.ZFeatureMap.mdx b/docs/api/qiskit/qiskit.circuit.library.ZFeatureMap.mdx index 184c8bc68c2..a328d3e898e 100644 --- a/docs/api/qiskit/qiskit.circuit.library.ZFeatureMap.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.ZFeatureMap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.ZFeatureMap # ZFeatureMap - + Bases: [`PauliFeatureMap`](qiskit.circuit.library.PauliFeatureMap "qiskit.circuit.library.data_preparation.pauli_feature_map.PauliFeatureMap") The first order Pauli Z-evolution circuit. @@ -91,7 +91,7 @@ python_api_name: qiskit.circuit.library.ZFeatureMap ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -105,7 +105,7 @@ python_api_name: qiskit.circuit.library.ZFeatureMap ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -145,7 +145,7 @@ python_api_name: qiskit.circuit.library.ZFeatureMap ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -170,7 +170,7 @@ python_api_name: qiskit.circuit.library.ZFeatureMap ### instances - + ### layout @@ -185,9 +185,9 @@ python_api_name: qiskit.circuit.library.ZFeatureMap ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -196,12 +196,36 @@ python_api_name: qiskit.circuit.library.ZFeatureMap Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.ZFeatureMap.num_input_vars "qiskit.circuit.library.ZFeatureMap.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.ZFeatureMap.num_captured_vars "qiskit.circuit.library.ZFeatureMap.num_captured_vars") must be zero. + + ### num\_layers @@ -232,6 +256,14 @@ python_api_name: qiskit.circuit.library.ZFeatureMap The number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -315,13 +347,13 @@ python_api_name: qiskit.circuit.library.ZFeatureMap ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -343,5 +375,29 @@ python_api_name: qiskit.circuit.library.ZFeatureMap The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.ZFeatureMap.unit "qiskit.circuit.library.ZFeatureMap.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.ZFeatureMap.duration "qiskit.circuit.library.ZFeatureMap.duration") is specified in. + diff --git a/docs/api/qiskit/qiskit.circuit.library.ZGate.mdx b/docs/api/qiskit/qiskit.circuit.library.ZGate.mdx index 2c8ff3bc333..e4f4b8f03df 100644 --- a/docs/api/qiskit/qiskit.circuit.library.ZGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.ZGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.ZGate # ZGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") The single-qubit Pauli-Z gate ($\sigma_z$). @@ -143,7 +143,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -156,7 +156,7 @@ $$ ### control - + Return a (multi-)controlled-Z gate. One control returns a CZ gate. @@ -165,7 +165,7 @@ $$ * **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)") *| 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)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. + * **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*) – control state expressed as integer, string (e.g.\`\`’110’`), or ``None`. If `None`, use all 1s. * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the controlled gate can be implemented as an annotated gate. **Returns** @@ -179,7 +179,7 @@ $$ ### inverse - + Return inverted Z gate (itself). **Parameters** @@ -197,8 +197,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.circuit.library.ZZFeatureMap.mdx b/docs/api/qiskit/qiskit.circuit.library.ZZFeatureMap.mdx index 9898678bdae..efda01c706f 100644 --- a/docs/api/qiskit/qiskit.circuit.library.ZZFeatureMap.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.ZZFeatureMap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap # ZZFeatureMap - + Bases: [`PauliFeatureMap`](qiskit.circuit.library.PauliFeatureMap "qiskit.circuit.library.data_preparation.pauli_feature_map.PauliFeatureMap") Second-order Pauli-Z evolution circuit. @@ -96,7 +96,7 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -110,7 +110,7 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data @@ -150,7 +150,7 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### initial\_state @@ -175,7 +175,7 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap ### instances - + ### layout @@ -190,9 +190,9 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -201,12 +201,36 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.circuit.library.ZZFeatureMap.num_input_vars "qiskit.circuit.library.ZZFeatureMap.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.circuit.library.ZZFeatureMap.num_captured_vars "qiskit.circuit.library.ZZFeatureMap.num_captured_vars") must be zero. + + ### num\_layers @@ -237,6 +261,14 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap The number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -320,13 +352,13 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap ### qregs - A list of the quantum registers associated with the circuit. + A list of the `QuantumRegister`s in this circuit. You should not mutate this. ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### reps @@ -348,5 +380,29 @@ python_api_name: qiskit.circuit.library.ZZFeatureMap The blocks in the rotation layers. + + ### name + + + A human-readable name for the circuit. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.circuit.library.ZZFeatureMap.unit "qiskit.circuit.library.ZZFeatureMap.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.circuit.library.ZZFeatureMap.duration "qiskit.circuit.library.ZZFeatureMap.duration") is specified in. + diff --git a/docs/api/qiskit/qiskit.circuit.library.iSwapGate.mdx b/docs/api/qiskit/qiskit.circuit.library.iSwapGate.mdx index 11eb6835273..63e428980a8 100644 --- a/docs/api/qiskit/qiskit.circuit.library.iSwapGate.mdx +++ b/docs/api/qiskit/qiskit.circuit.library.iSwapGate.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.circuit.library.iSwapGate # iSwapGate - + Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") iSWAP gate. @@ -156,7 +156,7 @@ $$ ### params - return instruction params. + The parameters of this `Instruction`. Ideally these will be gate angles. ### unit @@ -169,8 +169,23 @@ $$ ### power - - Raise gate to a power. + + Raise this gate to the power of `exponent`. + + Implemented either as a unitary gate (ref. [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")) or as an annotated operation (ref. [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), when the power of a gate can be expressed in terms of another standard gate that is returned directly. + + **Parameters** + + * **exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the gate to + * **annotated** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – indicates whether the power gate can be implemented as an annotated operation. In the case of several standard gates, such as [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), this argument is ignored when the power of a gate can be expressed in terms of another standard gate. + + **Returns** + + An operation implementing `gate^exponent` + + **Raises** + + [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If gate is not unitary diff --git a/docs/api/qiskit/qiskit.dagcircuit.DAGCircuit.mdx b/docs/api/qiskit/qiskit.dagcircuit.DAGCircuit.mdx index dff8b616711..a8a11d2f957 100644 --- a/docs/api/qiskit/qiskit.dagcircuit.DAGCircuit.mdx +++ b/docs/api/qiskit/qiskit.dagcircuit.DAGCircuit.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit # DAGCircuit - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Quantum circuit as a directed acyclic graph. @@ -41,6 +41,30 @@ python_api_name: qiskit.dagcircuit.DAGCircuit Returns the number of nodes in the dag. + ### num\_captured\_vars + + + Number of captured classical variables tracked by the circuit. + + + ### num\_declared\_vars + + + Number of declared local classical variables tracked by the circuit. + + + ### num\_input\_vars + + + Number of input classical variables tracked by the circuit. + + + ### num\_vars + + + Total number of classical variables tracked by the circuit. + + ### wires @@ -51,7 +75,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### add\_calibration - + Register a low-level, custom pulse definition for the given gate. **Parameters** @@ -66,47 +90,77 @@ python_api_name: qiskit.dagcircuit.DAGCircuit [**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\_captured\_var + + + Add a captured variable to the circuit. + + **Parameters** + + **var** ([*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")) – the variable to add. + + ### add\_clbits - + Add individual clbit wires. ### add\_creg - + Add all wires in a classical register. + ### add\_declared\_var + + + Add a declared local variable to the circuit. + + **Parameters** + + **var** ([*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")) – the variable to add. + + + ### add\_input\_var + + + Add an input variable to the circuit. + + **Parameters** + + **var** ([*Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")) – the variable to add. + + ### add\_qreg - + Add all wires in a quantum register. ### add\_qubits - + Add individual qubit wires. ### ancestors - + Returns set of the ancestors of a node as DAGOpNodes and DAGInNodes. ### apply\_operation\_back - + 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. + * **qargs** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*Qubit*](circuit#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*](circuit#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`](circuit#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** @@ -123,15 +177,15 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### apply\_operation\_front - + 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. + * **qargs** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*Qubit*](circuit#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*](circuit#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`](circuit#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** @@ -148,37 +202,41 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### bfs\_successors - + 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 - + Returns iterator of the predecessors of a node that are connected by a classical edge as DAGOpNodes and DAGInNodes. ### classical\_successors - + Returns iterator of the successors of a node that are connected by a classical edge as DAGOpNodes and DAGInNodes. ### collect\_1q\_runs - + Return a set of non-conditional runs of 1q “op” nodes. + + **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)")\[[qiskit.dagcircuit.dagnode.DAGOpNode](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.dagnode.DAGOpNode")]] ### collect\_2q\_runs - + Return a set of non-conditional runs of 2q “op” nodes. ### collect\_runs - + 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. @@ -188,7 +246,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### compose - + 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. @@ -198,10 +256,11 @@ python_api_name: qiskit.dagcircuit.DAGCircuit **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. + * **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Qubit*](circuit#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*](circuit#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. + * **inline\_captures** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True`, variables marked as “captures” in the `other` DAG will inlined onto existing uses of those same variables in `self`. If `False`, all variables in `other` are required to be distinct from `self`, and they will be added to `self`. **Returns** @@ -218,7 +277,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### copy\_empty\_like - + Return a copy of self with the same structure but empty. **That structure includes:** @@ -226,7 +285,26 @@ python_api_name: qiskit.dagcircuit.DAGCircuit * name and other metadata * global phase * duration - * all the qubits and clbits, including the registers. + * all the qubits and clbits, including the registers + * all the classical variables, with a mode defined by `vars_mode`. + + **Parameters** + + **vars\_mode** ([*Literal*](https://docs.python.org/3/library/typing.html#typing.Literal "(in Python v3.12)")*\['alike', 'captures', 'drop']*) – + + The mode to handle realtime variables in. + + **alike** + + The variables in the output DAG will have the same declaration semantics as in the original circuit. For example, `input` variables in the source will be `input` variables in the output DAG. + + **captures** + + All variables will be converted to captured variables. This is useful when you are building a new layer for an existing DAG that you will want to [`compose()`](#qiskit.dagcircuit.DAGCircuit.compose "qiskit.dagcircuit.DAGCircuit.compose") onto the base, since [`compose()`](#qiskit.dagcircuit.DAGCircuit.compose "qiskit.dagcircuit.DAGCircuit.compose") can inline captures onto the base circuit (but not other variables). + + **drop** + + The output DAG will have no variables defined. **Returns** @@ -239,7 +317,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### count\_ops - + Count the occurrences of operation names. **Parameters** @@ -257,7 +335,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### count\_ops\_longest\_path - + Count the occurrences of operation names on the longest path. Returns a dictionary of counts keyed on the operation name. @@ -265,7 +343,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### depth - + 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** @@ -288,13 +366,13 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### descendants - + Returns set of the descendants of a node as DAGOpNodes and DAGOutNodes. ### draw - + 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. @@ -316,7 +394,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### edges - + 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. @@ -336,12 +414,12 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### find\_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. + **bit** ([*Bit*](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit")) – The bit to locate. **Returns** @@ -360,13 +438,13 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### front\_layer - + Return a list of op nodes in the first layer of this dag. ### gate\_nodes - + Get the list of gate nodes in the dag. **Returns** @@ -380,13 +458,27 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### has\_calibration\_for - + 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. + ### has\_var + + + Is this realtime variable in the DAG? + + **Parameters** + + **var** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*expr.Var*](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var")) – the variable or name to check. + + **Return type** + + [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + ### idle\_wires - + Return idle wires. **Parameters** @@ -404,19 +496,43 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### is\_predecessor - + Checks if a second node is in the predecessors of node. ### is\_successor - + Checks if a second node is in the successors of node. + ### iter\_captured\_vars + + + Iterable over the captured classical variables tracked by the circuit. + + + ### iter\_declared\_vars + + + Iterable over the declared local classical variables tracked by the circuit. + + + ### iter\_input\_vars + + + Iterable over the input classical variables tracked by the circuit. + + + ### iter\_vars + + + Iterable over all the classical variables tracked by the circuit. + + ### 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}. @@ -424,35 +540,39 @@ python_api_name: qiskit.dagcircuit.DAGCircuit 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. + + **Parameters** + + **vars\_mode** ([*Literal*](https://docs.python.org/3/library/typing.html#typing.Literal "(in Python v3.12)")*\['alike', 'captures', 'drop']*) – how any realtime [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes should be handled in the output DAGs. See [`copy_empty_like()`](#qiskit.dagcircuit.DAGCircuit.copy_empty_like "qiskit.dagcircuit.DAGCircuit.copy_empty_like") for details on the modes. ### longest\_path - + Returns the longest path in the dag as a list of DAGOpNodes, DAGInNodes, and DAGOutNodes. ### multi\_qubit\_ops - + Get list of 3+ qubit operations. Ignore directives like snapshot and barrier. ### multigraph\_layers - + Yield layers of the multigraph. ### named\_nodes - + Get the set of “op” nodes with the given name. ### node - + Get the node in the dag. **Parameters** @@ -470,7 +590,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### nodes - + Iterator for node values. **Yields** @@ -480,12 +600,12 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### nodes\_on\_wire - + Iterator for nodes that affect a given wire. **Parameters** - * **wire** ([*Bit*](qiskit.circuit.Bit "qiskit.circuit.Bit")) – the wire to be looked at. + * **wire** ([*Bit*](circuit#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** @@ -499,25 +619,25 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### num\_clbits - + Return the total number of classical bits used by the circuit. ### 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 - + Compute how many components the circuit can decompose into. ### op\_nodes - + Get the list of “op” nodes in the dag. **Parameters** @@ -534,21 +654,33 @@ python_api_name: qiskit.dagcircuit.DAGCircuit [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[DAGOpNode](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")] + ### op\_predecessors + + + Returns the iterator of “op” predecessors of a node in the dag. + + + ### op\_successors + + + Returns iterator of “op” successors of a node in the dag. + + ### predecessors - + Returns iterator of the predecessors of a node as DAGOpNodes and DAGInNodes. ### properties - + Return a dictionary of circuit properties. ### quantum\_causal\_cone - + 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. @@ -557,7 +689,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit **Parameters** - **qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")) – The output qubit for which we want to find the causal cone. + **qubit** ([*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")) – The output qubit for which we want to find the causal cone. **Returns** @@ -565,50 +697,50 @@ python_api_name: qiskit.dagcircuit.DAGCircuit **Return type** - Set\[[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")] + Set\[[*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit")] ### quantum\_predecessors - + Returns iterator of the predecessors of a node that are connected by a quantum edge as DAGOpNodes and DAGInNodes. ### quantum\_successors - + 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 operation nodes with the given name. ### remove\_ancestors\_of - + Remove all of the ancestor operation nodes of node. ### remove\_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. + **clbits** (*List\[*[*Clbit*](circuit#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. + [**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – a clbit is not a [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit"), is not in the circuit, or is not idle. ### remove\_cregs - + Remove classical registers from the circuit, leaving underlying bits in place. **Raises** @@ -619,25 +751,25 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### remove\_descendants\_of - + Remove all of the descendant operation nodes of node. ### remove\_nonancestors\_of - + Remove all of the non-ancestors operation nodes of node. ### remove\_nondescendants\_of - + Remove all of the non-descendants operation nodes of node. ### remove\_op\_node - + Remove an operation node n. Add edges from predecessors to successors. @@ -645,7 +777,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### remove\_qregs - + Remove classical registers from the circuit, leaving underlying bits in place. **Raises** @@ -656,21 +788,21 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### remove\_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. + **qubits** (*List\[*[*Qubit*](circuit#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. + [**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – a qubit is not a [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit"), is not in the circuit, or is not idle. ### replace\_block\_with\_op - + 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. @@ -679,7 +811,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit * **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. + * **wire\_pos\_map** (*Dict\[*[*Bit*](circuit#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`](circuit#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. [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") wires similarly do not need to be in this map, since they will never be in `qargs` or `cargs`. * **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** @@ -697,7 +829,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### reverse\_ops - + Reverse the operations in the `self` circuit. **Returns** @@ -711,12 +843,13 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### separable\_circuits - + 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`. + * **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`. + * **vars\_mode** ([*Literal*](https://docs.python.org/3/library/typing.html#typing.Literal "(in Python v3.12)")*\['alike', 'captures', 'drop']*) – how any realtime [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes should be handled in the output DAGs. See [`copy_empty_like()`](#qiskit.dagcircuit.DAGCircuit.copy_empty_like "qiskit.dagcircuit.DAGCircuit.copy_empty_like") for details on the modes. **Returns** @@ -733,15 +866,19 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### 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(). + + **Parameters** + + **vars\_mode** ([*Literal*](https://docs.python.org/3/library/typing.html#typing.Literal "(in Python v3.12)")*\['alike', 'captures', 'drop']*) – how any realtime [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes should be handled in the output DAGs. See [`copy_empty_like()`](#qiskit.dagcircuit.DAGCircuit.copy_empty_like "qiskit.dagcircuit.DAGCircuit.copy_empty_like") for details on the modes. ### size - + 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** @@ -763,7 +900,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### substitute\_node - + 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** @@ -789,14 +926,21 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### substitute\_node\_with\_dag - + 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. + + * **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*](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit")*] | Dict\[*[*Bit*](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit")*,* [*Bit*](circuit#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. + + Standalone [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes cannot currently be remapped as part of the substitution; the `input_dag` should be defined over the correct set of variables already. + * **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 fulfill the same conditional logic or this function would be close to useless for them. **Returns** @@ -814,13 +958,13 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### successors - + Returns iterator of the successors of a node as DAGOpNodes and DAGOutNodes. ### swap\_nodes - + Swap connected nodes e.g. due to commutation. **Parameters** @@ -835,7 +979,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### topological\_nodes - + Yield nodes in topological order. **Parameters** @@ -853,7 +997,7 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### topological\_op\_nodes - + Yield op nodes in topological order. Allowed to pass in specific key to break ties in top order @@ -873,13 +1017,13 @@ python_api_name: qiskit.dagcircuit.DAGCircuit ### two\_qubit\_ops - + Get list of 2 qubit operations. Ignore directives like snapshot and barrier. ### 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/qiskit.dagcircuit.DAGDepNode.mdx b/docs/api/qiskit/qiskit.dagcircuit.DAGDepNode.mdx index a722b2b617f..34f214cfc10 100644 --- a/docs/api/qiskit/qiskit.dagcircuit.DAGDepNode.mdx +++ b/docs/api/qiskit/qiskit.dagcircuit.DAGDepNode.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.dagcircuit.DAGDepNode # DAGDepNode - + 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(). @@ -31,7 +31,7 @@ python_api_name: qiskit.dagcircuit.DAGDepNode ### sort\_key - + ### node\_id @@ -39,11 +39,11 @@ python_api_name: qiskit.dagcircuit.DAGDepNode ### successors - + ### predecessors - + ### reachable @@ -51,23 +51,23 @@ python_api_name: qiskit.dagcircuit.DAGDepNode ### matchedwith - + ### isblocked - + ### successorstovisit - + ### qindices - + ### cindices - + ### op @@ -85,13 +85,13 @@ python_api_name: qiskit.dagcircuit.DAGDepNode ### copy - + Function to copy a DAGDepNode object. :returns: a copy of a DAGDepNode object. :rtype: DAGDepNode ### semantic\_eq - + Check if DAG nodes are considered equivalent, e.g., as a node\_match for nx.is\_isomorphic. **Parameters** diff --git a/docs/api/qiskit/qiskit.dagcircuit.DAGDependency.mdx b/docs/api/qiskit/qiskit.dagcircuit.DAGDependency.mdx index 2f8e9ddf5e4..e95472047e6 100644 --- a/docs/api/qiskit/qiskit.dagcircuit.DAGDependency.mdx +++ b/docs/api/qiskit/qiskit.dagcircuit.DAGDependency.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency # DAGDependency - + 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). @@ -57,55 +57,55 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### add\_clbits - + Add individual clbit wires. ### add\_creg - + Add clbits in a classical register. ### add\_op\_node - + 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 + * **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Qubit*](circuit#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*](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit")*]*) – list of classical wires to attach to ### add\_qreg - + Add qubits in a quantum register. ### add\_qubits - + Add individual qubit wires. ### copy - + Function to copy a DAGDependency object. :returns: a copy of a DAGDependency object. :rtype: DAGDependency ### depth - + Return the circuit depth. :returns: the circuit depth :rtype: int ### direct\_predecessors - + Direct predecessors id of a given node as sorted list. **Parameters** @@ -123,7 +123,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### direct\_successors - + Direct successors id of a given node as sorted list. **Parameters** @@ -141,7 +141,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### draw - + 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. @@ -163,7 +163,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### get\_all\_edges - + Enumeration of all edges. **Returns** @@ -177,7 +177,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### get\_edges - + Edge enumeration between two nodes through method get\_all\_edge\_data. **Parameters** @@ -196,7 +196,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### get\_in\_edges - + Enumeration of all incoming edges for a given node. **Parameters** @@ -214,7 +214,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### get\_node - + **Parameters** **node\_id** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – label of considered node. @@ -230,7 +230,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### get\_nodes - + **Returns** iterator over all the nodes. @@ -242,7 +242,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### get\_out\_edges - + Enumeration of all outgoing edges for a given node. **Parameters** @@ -260,7 +260,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### predecessors - + Predecessors id of a given node as sorted list. **Parameters** @@ -278,7 +278,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### replace\_block\_with\_op - + 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. @@ -289,7 +289,7 @@ python_api_name: qiskit.dagcircuit.DAGDependency * **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. + * **wire\_pos\_map** (*Dict\[*[*Qubit*](circuit#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** @@ -299,13 +299,13 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### size - + Returns the number of gates in the circuit ### successors - + Successors id of a given node as sorted list. **Parameters** @@ -323,13 +323,13 @@ python_api_name: qiskit.dagcircuit.DAGDependency ### to\_retworkx - + Returns the DAGDependency in retworkx format. ### topological\_nodes - + Yield nodes in topological order. **Returns** diff --git a/docs/api/qiskit/qiskit.dagcircuit.DAGInNode.mdx b/docs/api/qiskit/qiskit.dagcircuit.DAGInNode.mdx index ef8b942b319..f7d836024c4 100644 --- a/docs/api/qiskit/qiskit.dagcircuit.DAGInNode.mdx +++ b/docs/api/qiskit/qiskit.dagcircuit.DAGInNode.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.dagcircuit.DAGInNode # DAGInNode - + Bases: [`DAGNode`](qiskit.dagcircuit.DAGNode "qiskit.dagcircuit.dagnode.DAGNode") Object to represent an incoming wire node in the DAGCircuit. @@ -29,7 +29,7 @@ python_api_name: qiskit.dagcircuit.DAGInNode ### semantic\_eq - + 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)"). **Parameters** diff --git a/docs/api/qiskit/qiskit.dagcircuit.DAGNode.mdx b/docs/api/qiskit/qiskit.dagcircuit.DAGNode.mdx index 9210f2fb34d..9db81fb6cc0 100644 --- a/docs/api/qiskit/qiskit.dagcircuit.DAGNode.mdx +++ b/docs/api/qiskit/qiskit.dagcircuit.DAGNode.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.dagcircuit.DAGNode # DAGNode - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Parent class for DAGOpNode, DAGInNode, and DAGOutNode. @@ -19,7 +19,7 @@ python_api_name: qiskit.dagcircuit.DAGNode ### semantic\_eq - + 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)"). **Parameters** diff --git a/docs/api/qiskit/qiskit.dagcircuit.DAGOpNode.mdx b/docs/api/qiskit/qiskit.dagcircuit.DAGOpNode.mdx index 2af56d7d273..f3893daa61d 100644 --- a/docs/api/qiskit/qiskit.dagcircuit.DAGOpNode.mdx +++ b/docs/api/qiskit/qiskit.dagcircuit.DAGOpNode.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.dagcircuit.DAGOpNode # DAGOpNode - + Bases: [`DAGNode`](qiskit.dagcircuit.DAGNode "qiskit.dagcircuit.dagnode.DAGNode") Object to represent an Instruction at a node in the DAGCircuit. @@ -43,7 +43,7 @@ python_api_name: qiskit.dagcircuit.DAGOpNode ### semantic\_eq - + 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)"). **Parameters** diff --git a/docs/api/qiskit/qiskit.dagcircuit.DAGOutNode.mdx b/docs/api/qiskit/qiskit.dagcircuit.DAGOutNode.mdx index 23c372e389d..2173bbcd59b 100644 --- a/docs/api/qiskit/qiskit.dagcircuit.DAGOutNode.mdx +++ b/docs/api/qiskit/qiskit.dagcircuit.DAGOutNode.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.dagcircuit.DAGOutNode # DAGOutNode - + Bases: [`DAGNode`](qiskit.dagcircuit.DAGNode "qiskit.dagcircuit.dagnode.DAGNode") Object to represent an outgoing wire node in the DAGCircuit. @@ -29,7 +29,7 @@ python_api_name: qiskit.dagcircuit.DAGOutNode ### semantic\_eq - + 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)"). **Parameters** diff --git a/docs/api/qiskit/qiskit.passmanager.BaseController.mdx b/docs/api/qiskit/qiskit.passmanager.BaseController.mdx index 4f4c4af3d83..84543c0611b 100644 --- a/docs/api/qiskit/qiskit.passmanager.BaseController.mdx +++ b/docs/api/qiskit/qiskit.passmanager.BaseController.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.BaseController # BaseController - + Bases: `Task`, [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Base class of controller. @@ -25,7 +25,7 @@ python_api_name: qiskit.passmanager.BaseController ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -45,7 +45,7 @@ python_api_name: qiskit.passmanager.BaseController ### iter\_tasks - + 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. diff --git a/docs/api/qiskit/qiskit.passmanager.BasePassManager.mdx b/docs/api/qiskit/qiskit.passmanager.BasePassManager.mdx index 7bee8f79277..8a55d5c2cd2 100644 --- a/docs/api/qiskit/qiskit.passmanager.BasePassManager.mdx +++ b/docs/api/qiskit/qiskit.passmanager.BasePassManager.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.BasePassManager # BasePassManager - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Pass manager base class. @@ -24,7 +24,7 @@ python_api_name: qiskit.passmanager.BasePassManager ### append - + Append tasks to the schedule of passes. **Parameters** @@ -38,7 +38,7 @@ python_api_name: qiskit.passmanager.BasePassManager ### remove - + Removes a particular pass in the scheduler. **Parameters** @@ -52,7 +52,7 @@ python_api_name: qiskit.passmanager.BasePassManager ### replace - + Replace a particular pass in the scheduler. **Parameters** @@ -68,7 +68,7 @@ python_api_name: qiskit.passmanager.BasePassManager ### run - + Run all the passes on the specified `in_programs`. **Parameters** @@ -116,7 +116,7 @@ python_api_name: qiskit.passmanager.BasePassManager ### 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** diff --git a/docs/api/qiskit/qiskit.passmanager.ConditionalController.mdx b/docs/api/qiskit/qiskit.passmanager.ConditionalController.mdx index acbdd5005a8..eb6291d972b 100644 --- a/docs/api/qiskit/qiskit.passmanager.ConditionalController.mdx +++ b/docs/api/qiskit/qiskit.passmanager.ConditionalController.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.ConditionalController # ConditionalController - + 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. @@ -31,7 +31,7 @@ python_api_name: qiskit.passmanager.ConditionalController ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -51,7 +51,7 @@ python_api_name: qiskit.passmanager.ConditionalController ### iter\_tasks - + 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. diff --git a/docs/api/qiskit/qiskit.passmanager.DoWhileController.mdx b/docs/api/qiskit/qiskit.passmanager.DoWhileController.mdx index 43928834483..d4deebaaab0 100644 --- a/docs/api/qiskit/qiskit.passmanager.DoWhileController.mdx +++ b/docs/api/qiskit/qiskit.passmanager.DoWhileController.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.DoWhileController # DoWhileController - + 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`. @@ -33,7 +33,7 @@ python_api_name: qiskit.passmanager.DoWhileController ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -53,7 +53,7 @@ python_api_name: qiskit.passmanager.DoWhileController ### iter\_tasks - + 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. diff --git a/docs/api/qiskit/qiskit.passmanager.FlowControllerLinear.mdx b/docs/api/qiskit/qiskit.passmanager.FlowControllerLinear.mdx index 17b9f6c04bd..4a1a321a85e 100644 --- a/docs/api/qiskit/qiskit.passmanager.FlowControllerLinear.mdx +++ b/docs/api/qiskit/qiskit.passmanager.FlowControllerLinear.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.FlowControllerLinear # FlowControllerLinear - + Bases: [`BaseController`](qiskit.passmanager.BaseController "qiskit.passmanager.base_tasks.BaseController") A standard flow controller that runs tasks one after the other. @@ -31,7 +31,7 @@ python_api_name: qiskit.passmanager.FlowControllerLinear ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -51,7 +51,7 @@ python_api_name: qiskit.passmanager.FlowControllerLinear ### iter\_tasks - + 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. diff --git a/docs/api/qiskit/qiskit.passmanager.GenericPass.mdx b/docs/api/qiskit/qiskit.passmanager.GenericPass.mdx index 3f8924bc2b0..02d3a2aa744 100644 --- a/docs/api/qiskit/qiskit.passmanager.GenericPass.mdx +++ b/docs/api/qiskit/qiskit.passmanager.GenericPass.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.GenericPass # GenericPass - + 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. @@ -19,7 +19,7 @@ python_api_name: qiskit.passmanager.GenericPass ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -39,7 +39,7 @@ python_api_name: qiskit.passmanager.GenericPass ### name - + Name of the pass. **Return type** @@ -49,7 +49,7 @@ python_api_name: qiskit.passmanager.GenericPass ### run - + Run optimization task. **Parameters** @@ -67,7 +67,7 @@ python_api_name: qiskit.passmanager.GenericPass ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.passmanager.PassManagerState.mdx b/docs/api/qiskit/qiskit.passmanager.PassManagerState.mdx index a6eb9a5e81e..82171b02d38 100644 --- a/docs/api/qiskit/qiskit.passmanager.PassManagerState.mdx +++ b/docs/api/qiskit/qiskit.passmanager.PassManagerState.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.PassManagerState # PassManagerState - + 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. diff --git a/docs/api/qiskit/qiskit.passmanager.PropertySet.mdx b/docs/api/qiskit/qiskit.passmanager.PropertySet.mdx index 33d4f3245a0..ce19abd3eb2 100644 --- a/docs/api/qiskit/qiskit.passmanager.PropertySet.mdx +++ b/docs/api/qiskit/qiskit.passmanager.PropertySet.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.PropertySet # PropertySet - + Bases: [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") A default dictionary-like object. diff --git a/docs/api/qiskit/qiskit.passmanager.WorkflowStatus.mdx b/docs/api/qiskit/qiskit.passmanager.WorkflowStatus.mdx index 969db6ac506..b818a9f5c47 100644 --- a/docs/api/qiskit/qiskit.passmanager.WorkflowStatus.mdx +++ b/docs/api/qiskit/qiskit.passmanager.WorkflowStatus.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.passmanager.WorkflowStatus # WorkflowStatus - + 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. diff --git a/docs/api/qiskit/qiskit.primitives.BackendEstimator.mdx b/docs/api/qiskit/qiskit.primitives.BackendEstimator.mdx index d565cd1719d..5ca00bd6325 100644 --- a/docs/api/qiskit/qiskit.primitives.BackendEstimator.mdx +++ b/docs/api/qiskit/qiskit.primitives.BackendEstimator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BackendEstimator # BackendEstimator - + Bases: [`BaseEstimatorV1`](qiskit.primitives.BaseEstimatorV1 "qiskit.primitives.base.base_estimator.BaseEstimatorV1")\[[`PrimitiveJob`](qiskit.primitives.PrimitiveJob "qiskit.primitives.primitive_job.PrimitiveJob")\[[`EstimatorResult`](qiskit.primitives.EstimatorResult "qiskit.primitives.base.estimator_result.EstimatorResult")]] Evaluates expectation value using Pauli rotation gates. @@ -69,7 +69,7 @@ python_api_name: qiskit.primitives.BackendEstimator ### run - + 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 @@ -113,7 +113,7 @@ python_api_name: qiskit.primitives.BackendEstimator ### set\_options - + Set options values for the estimator. **Parameters** @@ -123,7 +123,7 @@ python_api_name: qiskit.primitives.BackendEstimator ### set\_transpile\_options - + Set the transpiler options for transpiler. :param \*\*fields: The fields to update the options diff --git a/docs/api/qiskit/qiskit.primitives.BackendEstimatorV2.mdx b/docs/api/qiskit/qiskit.primitives.BackendEstimatorV2.mdx new file mode 100644 index 00000000000..df48f7a7488 --- /dev/null +++ b/docs/api/qiskit/qiskit.primitives.BackendEstimatorV2.mdx @@ -0,0 +1,68 @@ +--- +title: BackendEstimatorV2 +description: API reference for qiskit.primitives.BackendEstimatorV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.BackendEstimatorV2 +--- + +# BackendEstimatorV2 + + + Bases: [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.base.base_estimator.BaseEstimatorV2") + + Evaluates expectation values for provided quantum circuit and observable combinations + + The [`BackendEstimatorV2`](#qiskit.primitives.BackendEstimatorV2 "qiskit.primitives.BackendEstimatorV2") class is a generic implementation of the [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") 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 [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") API. It facilitates using backends that do not provide a native [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") implementation in places that work with [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2"). However, if you’re using a provider that has a native implementation of [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2"), 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. + + This class does not perform any measurement or gate mitigation, and, presently, is only compatible with Pauli-based observables. + + Each tuple of `(circuit, observables, parameter values, precision)`, called an estimator primitive unified bloc (PUB), produces its own array-based result. The [`run()`](#qiskit.primitives.BackendEstimatorV2.run "qiskit.primitives.BackendEstimatorV2.run") method can be given a sequence of pubs to run in one call. + + The options for [`BackendEstimatorV2`](#qiskit.primitives.BackendEstimatorV2 "qiskit.primitives.BackendEstimatorV2") consist of the following items. + + * `default_precision`: The default precision to use if none are specified in [`run()`](#qiskit.primitives.BackendEstimatorV2.run "qiskit.primitives.BackendEstimatorV2.run"). Default: 0.015625 (1 / sqrt(4096)). + * `abelian_grouping`: Whether the observables should be grouped into sets of qubit-wise commuting observables. Default: True. + * `seed_simulator`: The seed to use in the simulator. If None, a random seed will be used. Default: None. + + **Parameters** + + * **backend** ([*BackendV1*](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") *|*[*BackendV2*](qiskit.providers.BackendV2 "qiskit.providers.BackendV2")) – The backend to run the primitive on. + * **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – The options to control the default precision (`default_precision`), the operator grouping (`abelian_grouping`), and the random seed for the simulator (`seed_simulator`). + + ## Attributes + + ### backend + + + Returns the backend which this sampler object based on. + + + ### options + + + Return the options + + + ## Methods + + ### run + + + Estimate expectation values for each provided pub (Primitive Unified Bloc). + + **Parameters** + + * **pubs** (*Iterable\[EstimatorPubLike]*) – An iterable of pub-like objects, such as tuples `(circuit, observables)` or `(circuit, observables, parameter_values)`. + * **precision** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The target precision for expectation value estimates of each run Estimator Pub that does not specify its own precision. If None the estimator’s default precision value will be used. + + **Returns** + + A job object that contains results. + + **Return type** + + [PrimitiveJob](qiskit.primitives.PrimitiveJob "qiskit.primitives.PrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[[PubResult](qiskit.primitives.PubResult "qiskit.primitives.PubResult")]] + + + diff --git a/docs/api/qiskit/qiskit.primitives.BackendSampler.mdx b/docs/api/qiskit/qiskit.primitives.BackendSampler.mdx index e73dcb81ad5..9c5bf541423 100644 --- a/docs/api/qiskit/qiskit.primitives.BackendSampler.mdx +++ b/docs/api/qiskit/qiskit.primitives.BackendSampler.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BackendSampler # BackendSampler - + Bases: [`BaseSamplerV1`](qiskit.primitives.BaseSamplerV1 "qiskit.primitives.base.base_sampler.BaseSamplerV1")\[[`PrimitiveJob`](qiskit.primitives.PrimitiveJob "qiskit.primitives.primitive_job.PrimitiveJob")\[[`SamplerResult`](qiskit.primitives.SamplerResult "qiskit.primitives.base.sampler_result.SamplerResult")]] A `BaseSampler` implementation that provides an interface for leveraging the sampler interface from any backend. @@ -76,7 +76,7 @@ python_api_name: qiskit.primitives.BackendSampler ### run - + Run the job of the sampling of bitstrings. **Parameters** @@ -100,7 +100,7 @@ python_api_name: qiskit.primitives.BackendSampler ### set\_options - + Set options values for the estimator. **Parameters** @@ -110,7 +110,7 @@ python_api_name: qiskit.primitives.BackendSampler ### set\_transpile\_options - + Set the transpiler options for transpiler. :param \*\*fields: The fields to update the options. **Returns** diff --git a/docs/api/qiskit/qiskit.primitives.BackendSamplerV2.mdx b/docs/api/qiskit/qiskit.primitives.BackendSamplerV2.mdx new file mode 100644 index 00000000000..3990ca69b10 --- /dev/null +++ b/docs/api/qiskit/qiskit.primitives.BackendSamplerV2.mdx @@ -0,0 +1,71 @@ +--- +title: BackendSamplerV2 +description: API reference for qiskit.primitives.BackendSamplerV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.BackendSamplerV2 +--- + +# BackendSamplerV2 + + + Bases: [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.base.base_sampler.BaseSamplerV2") + + Evaluates bitstrings for provided quantum circuits + + The [`BackendSamplerV2`](#qiskit.primitives.BackendSamplerV2 "qiskit.primitives.BackendSamplerV2") class is a generic implementation of the [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") 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 class [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") API. It facilitates using backends that do not provide a native [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") implementation in places that work with [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2"). However, if you’re using a provider that has a native implementation of [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2"), 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. + + This class does not perform any measurement or gate mitigation. + + Each tuple of `(circuit, parameter values, shots)`, called a sampler primitive unified bloc (PUB), produces its own array-valued result. The [`run()`](#qiskit.primitives.BackendSamplerV2.run "qiskit.primitives.BackendSamplerV2.run") method can be given many pubs at once. + + The options for [`BackendSamplerV2`](#qiskit.primitives.BackendSamplerV2 "qiskit.primitives.BackendSamplerV2") consist of the following items. + + * `default_shots`: The default shots to use if none are specified in [`run()`](#qiskit.primitives.BackendSamplerV2.run "qiskit.primitives.BackendSamplerV2.run"). Default: 1024. + * `seed_simulator`: The seed to use in the simulator. If None, a random seed will be used. Default: None. + + + This class requires a backend that supports `memory` option. + + + **Parameters** + + * **backend** ([*BackendV1*](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") *|*[*BackendV2*](qiskit.providers.BackendV2 "qiskit.providers.BackendV2")) – The backend to run the primitive on. + * **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – The options to control the default shots (`default_shots`) and the random seed for the simulator (`seed_simulator`). + + ## Attributes + + ### backend + + + Returns the backend which this sampler object based on. + + + ### options + + + Return the options + + + ## Methods + + ### run + + + Run and collect samples from each pub. + + **Parameters** + + * **pubs** (*Iterable\[SamplerPubLike]*) – An iterable of pub-like objects. For example, a list of circuits or tuples `(circuit, parameter_values)`. + * **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The total number of shots to sample for each sampler pub that does not specify its own shots. If `None`, the primitive’s default shots value will be used, which can vary by implementation. + + **Returns** + + The job object of Sampler’s result. + + **Return type** + + [PrimitiveJob](qiskit.primitives.PrimitiveJob "qiskit.primitives.PrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[[SamplerPubResult](qiskit.primitives.SamplerPubResult "qiskit.primitives.SamplerPubResult")]] + + + diff --git a/docs/api/qiskit/qiskit.primitives.BaseEstimator.mdx b/docs/api/qiskit/qiskit.primitives.BaseEstimator.mdx index ebdc7ccb7df..256672acf78 100644 --- a/docs/api/qiskit/qiskit.primitives.BaseEstimator.mdx +++ b/docs/api/qiskit/qiskit.primitives.BaseEstimator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BaseEstimator # BaseEstimator - + alias of [`BaseEstimatorV1`](qiskit.primitives.BaseEstimatorV1 "qiskit.primitives.base.base_estimator.BaseEstimatorV1") diff --git a/docs/api/qiskit/qiskit.primitives.BaseEstimatorV1.mdx b/docs/api/qiskit/qiskit.primitives.BaseEstimatorV1.mdx index b1506cbb3de..a60feccf566 100644 --- a/docs/api/qiskit/qiskit.primitives.BaseEstimatorV1.mdx +++ b/docs/api/qiskit/qiskit.primitives.BaseEstimatorV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BaseEstimatorV1 # BaseEstimatorV1 - + Bases: `BasePrimitive`, [`Generic`](https://docs.python.org/3/library/typing.html#typing.Generic "(in Python v3.12)")\[`T`] Estimator V1 base class. @@ -82,7 +82,7 @@ $$ ### run - + 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 @@ -126,7 +126,7 @@ $$ ### set\_options - + Set options values for the estimator. **Parameters** diff --git a/docs/api/qiskit/qiskit.primitives.BaseEstimatorV2.mdx b/docs/api/qiskit/qiskit.primitives.BaseEstimatorV2.mdx index 6f2724a035f..bcaa16b5fa6 100644 --- a/docs/api/qiskit/qiskit.primitives.BaseEstimatorV2.mdx +++ b/docs/api/qiskit/qiskit.primitives.BaseEstimatorV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BaseEstimatorV2 # BaseEstimatorV2 - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Estimator V2 base class. @@ -21,7 +21,7 @@ python_api_name: qiskit.primitives.BaseEstimatorV2 ### run - + Estimate expectation values for each provided pub (Primitive Unified Bloc). **Parameters** diff --git a/docs/api/qiskit/qiskit.primitives.BasePrimitiveJob.mdx b/docs/api/qiskit/qiskit.primitives.BasePrimitiveJob.mdx index 2ccb2281c06..812f9d80f40 100644 --- a/docs/api/qiskit/qiskit.primitives.BasePrimitiveJob.mdx +++ b/docs/api/qiskit/qiskit.primitives.BasePrimitiveJob.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BasePrimitiveJob # BasePrimitiveJob - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)"), [`Generic`](https://docs.python.org/3/library/typing.html#typing.Generic "(in Python v3.12)")\[`ResultT`, `StatusT`] Primitive job abstract base class. @@ -24,13 +24,13 @@ python_api_name: qiskit.primitives.BasePrimitiveJob ### cancel - + Attempt to cancel the job. ### cancelled - + Return whether the job has been cancelled. **Return type** @@ -40,7 +40,7 @@ python_api_name: qiskit.primitives.BasePrimitiveJob ### done - + Return whether the job has successfully run. **Return type** @@ -50,7 +50,7 @@ python_api_name: qiskit.primitives.BasePrimitiveJob ### in\_final\_state - + Return whether the job is in a final job state such as `DONE` or `ERROR`. **Return type** @@ -60,7 +60,7 @@ python_api_name: qiskit.primitives.BasePrimitiveJob ### job\_id - + Return a unique id identifying the job. **Return type** @@ -70,7 +70,7 @@ python_api_name: qiskit.primitives.BasePrimitiveJob ### result - + Return the results of the job. **Return type** @@ -80,7 +80,7 @@ python_api_name: qiskit.primitives.BasePrimitiveJob ### running - + Return whether the job is actively running. **Return type** @@ -90,7 +90,7 @@ python_api_name: qiskit.primitives.BasePrimitiveJob ### status - + Return the status of the job. **Return type** diff --git a/docs/api/qiskit/qiskit.primitives.BaseSampler.mdx b/docs/api/qiskit/qiskit.primitives.BaseSampler.mdx index 1fff1e5773f..85e26d11ddb 100644 --- a/docs/api/qiskit/qiskit.primitives.BaseSampler.mdx +++ b/docs/api/qiskit/qiskit.primitives.BaseSampler.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BaseSampler # BaseSampler - + alias of [`BaseSamplerV1`](qiskit.primitives.BaseSamplerV1 "qiskit.primitives.base.base_sampler.BaseSamplerV1") diff --git a/docs/api/qiskit/qiskit.primitives.BaseSamplerV1.mdx b/docs/api/qiskit/qiskit.primitives.BaseSamplerV1.mdx index 815c5cdf450..d73a68a321f 100644 --- a/docs/api/qiskit/qiskit.primitives.BaseSamplerV1.mdx +++ b/docs/api/qiskit/qiskit.primitives.BaseSamplerV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BaseSamplerV1 # BaseSamplerV1 - + Bases: `BasePrimitive`, [`Generic`](https://docs.python.org/3/library/typing.html#typing.Generic "(in Python v3.12)")\[`T`] Sampler V1 base class @@ -81,7 +81,7 @@ python_api_name: qiskit.primitives.BaseSamplerV1 ### run - + Run the job of the sampling of bitstrings. **Parameters** @@ -105,7 +105,7 @@ python_api_name: qiskit.primitives.BaseSamplerV1 ### set\_options - + Set options values for the estimator. **Parameters** diff --git a/docs/api/qiskit/qiskit.primitives.BaseSamplerV2.mdx b/docs/api/qiskit/qiskit.primitives.BaseSamplerV2.mdx index 011ccd578fe..cef178257a3 100644 --- a/docs/api/qiskit/qiskit.primitives.BaseSamplerV2.mdx +++ b/docs/api/qiskit/qiskit.primitives.BaseSamplerV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BaseSamplerV2 # BaseSamplerV2 - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Sampler V2 base class. @@ -21,7 +21,7 @@ python_api_name: qiskit.primitives.BaseSamplerV2 ### run - + Run and collect samples from each pub. **Parameters** @@ -35,7 +35,7 @@ python_api_name: qiskit.primitives.BaseSamplerV2 **Return type** - [BasePrimitiveJob](qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[[PubResult](qiskit.primitives.PubResult "qiskit.primitives.PubResult")]] + [BasePrimitiveJob](qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[[SamplerPubResult](qiskit.primitives.SamplerPubResult "qiskit.primitives.SamplerPubResult")]] diff --git a/docs/api/qiskit/qiskit.primitives.BitArray.mdx b/docs/api/qiskit/qiskit.primitives.BitArray.mdx index e8ae6ea3751..8ce41afcab3 100644 --- a/docs/api/qiskit/qiskit.primitives.BitArray.mdx +++ b/docs/api/qiskit/qiskit.primitives.BitArray.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.BitArray # BitArray - + Bases: `ShapedMixin` Stores an array of bit values. @@ -65,7 +65,7 @@ python_api_name: qiskit.primitives.BitArray ### bitcount - + Compute the number of ones appearing in the binary representation of each shot. **Returns** @@ -77,9 +77,118 @@ python_api_name: qiskit.primitives.BitArray [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [*dtype*](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v1.26)")\[*uint64*]] + ### concatenate + + + Join a sequence of bit arrays along an existing axis. + + **Parameters** + + * **bit\_arrays** ([*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*BitArray*](#qiskit.primitives.BitArray "qiskit.primitives.containers.bit_array.BitArray")*]*) – The bit arrays must have (1) the same number of bits, (2) the same number of shots, and (3) the same shape, except in the dimension corresponding to axis (the first, by default). + * **axis** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The axis along which the arrays will be joined. Default is 0. + + **Returns** + + The concatenated bit array. + + **Raises** + + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the sequence of bit arrays is empty. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If any bit arrays has a different number of bits. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If any bit arrays has a different number of shots. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If any bit arrays has a different number of dimensions. + + **Return type** + + [*BitArray*](#qiskit.primitives.BitArray "qiskit.primitives.containers.bit_array.BitArray") + + + ### concatenate\_bits + + + Join a sequence of bit arrays along the bits axis. + + + This method is equivalent to per-shot bitstring concatenation. + + + **Parameters** + + **bit\_arrays** ([*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*BitArray*](#qiskit.primitives.BitArray "qiskit.primitives.containers.bit_array.BitArray")*]*) – Bit arrays that have (1) the same number of shots, and (2) the same shape. + + **Returns** + + The stacked bit array. + + **Raises** + + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the sequence of bit arrays is empty. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If any bit arrays has a different number of shots. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If any bit arrays has a different shape. + + **Return type** + + [*BitArray*](#qiskit.primitives.BitArray "qiskit.primitives.containers.bit_array.BitArray") + + + ### concatenate\_shots + + + Join a sequence of bit arrays along the shots axis. + + **Parameters** + + **bit\_arrays** ([*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*BitArray*](#qiskit.primitives.BitArray "qiskit.primitives.containers.bit_array.BitArray")*]*) – The bit arrays must have (1) the same number of bits, and (2) the same shape. + + **Returns** + + The stacked bit array. + + **Raises** + + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the sequence of bit arrays is empty. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If any bit arrays has a different number of bits. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If any bit arrays has a different shape. + + **Return type** + + [*BitArray*](#qiskit.primitives.BitArray "qiskit.primitives.containers.bit_array.BitArray") + + + ### expectation\_values + + + Compute the expectation values of the provided observables, broadcasted against this bit array. + + + This method returns the real part of the expectation value even if the operator has complex coefficients due to the specification of [`sampled_expectation_value()`](result#qiskit.result.sampled_expectation_value "qiskit.result.sampled_expectation_value"). + + + **Parameters** + + * **observables** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(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") *|*[*Mapping*](https://docs.python.org/3/library/typing.html#typing.Mapping "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.operators.symplectic.pauli.Pauli")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | \_SupportsArray\[*[*dtype*](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v1.26)")*\[*[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*]] | \_NestedSequence\[\_SupportsArray\[*[*dtype*](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v1.26)")*\[*[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*]]] |* [*bool*](https://docs.python.org/3/library/functions.html#bool "(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)") *|*[*bytes*](https://docs.python.org/3/library/stdtypes.html#bytes "(in Python v3.12)") *| \_NestedSequence\[*[*bool*](https://docs.python.org/3/library/functions.html#bool "(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)") *|*[*bytes*](https://docs.python.org/3/library/stdtypes.html#bytes "(in Python v3.12)")*]*) – The observable(s) to take the expectation value of. + * **and** (*Must have a shape broadcastable with with this bit array*) – + * **array.** (*the same number of qubits as the number of bits of this bit*) – + * **diagonal** (*The observables must be*) – + + **Returns** + + An array of expectation values whose shape is the broadcast shape of `observables` and this bit array. + + **Raises** + + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the provided observables does not have a shape broadcastable with this bit array. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the provided observables does not have the same number of qubits as the number of bits of this bit array. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the provided observables are not diagonal. + + **Return type** + + [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [*dtype*](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v1.26)")\[*float64*]] + + ### from\_bool\_array - + Construct a new bit array from an array of bools. **Parameters** @@ -98,7 +207,7 @@ python_api_name: qiskit.primitives.BitArray ### from\_counts - + Construct a new bit array from one or more `Counts`-like objects. The `counts` can have keys that are (uniformly) integers, hexstrings, or bitstrings. Their values represent numbers of occurrences of that value. @@ -124,7 +233,7 @@ python_api_name: qiskit.primitives.BitArray ### from\_samples - + Construct a new bit array from an iterable of bitstrings, hexstrings, or integers. All samples are assumed to be integers if the first one is. Strings are all assumed to be bitstrings whenever the first string doesn’t start with `"0x"`. @@ -151,7 +260,7 @@ python_api_name: qiskit.primitives.BitArray ### get\_bitstrings - + Return a list of bitstrings. **Parameters** @@ -169,7 +278,7 @@ python_api_name: qiskit.primitives.BitArray ### get\_counts - + Return a counts dictionary with bitstring keys. **Parameters** @@ -187,7 +296,7 @@ python_api_name: qiskit.primitives.BitArray ### get\_int\_counts - + Return a counts dictionary, where bitstrings are stored as `int`s. **Parameters** @@ -205,7 +314,7 @@ python_api_name: qiskit.primitives.BitArray ### reshape - + Return a new reshaped bit array. The [`num_shots`](#qiskit.primitives.BitArray.num_shots "qiskit.primitives.BitArray.num_shots") axis is either included or excluded from the reshaping procedure depending on which picture the new shape is compatible with. For example, for a bit array with shape `(20, 5)` and `64` shots, a reshape to `(100,)` would leave the number of shots intact, whereas a reshape to `(200, 32)` would change the number of shots to `32`. @@ -226,5 +335,78 @@ python_api_name: qiskit.primitives.BitArray [*BitArray*](#qiskit.primitives.BitArray "qiskit.primitives.containers.bit_array.BitArray") + + ### slice\_bits + + + Return a bit array sliced along the bit axis of some indices of interest. + + + The convention used by this method is that the index `0` corresponds to the least-significant bit in the [`array`](#qiskit.primitives.BitArray.array "qiskit.primitives.BitArray.array"), or equivalently the right-most bitstring entry as returned by [`get_counts()`](#qiskit.primitives.BitArray.get_counts "qiskit.primitives.BitArray.get_counts") or [`get_bitstrings()`](#qiskit.primitives.BitArray.get_bitstrings "qiskit.primitives.BitArray.get_bitstrings"), etc. + + If this bit array was produced by a sampler, then an index `i` corresponds to the [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") location `creg[i]`. + + + **Parameters** + + **indices** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| Sequence\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The bit positions of interest to slice along. + + **Returns** + + A bit array sliced along the bit axis. + + **Raises** + + [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If there are any invalid indices of the bit axis. + + **Return type** + + [BitArray](#qiskit.primitives.BitArray "qiskit.primitives.BitArray") + + + ### slice\_shots + + + Return a bit array sliced along the shots axis of some indices of interest. + + **Parameters** + + **indices** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| Sequence\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The shots positions of interest to slice along. + + **Returns** + + A bit array sliced along the shots axis. + + **Raises** + + [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If there are any invalid indices of the shots axis. + + **Return type** + + [BitArray](#qiskit.primitives.BitArray "qiskit.primitives.BitArray") + + + ### transpose + + + Return a bit array with axes transposed. + + **Parameters** + + **axes** – None, tuple of ints or n ints. See [ndarray.transpose](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.transpose.html#numpy.ndarray.transpose) for the details. + + **Returns** + + A bit array with axes permuted. + + **Return type** + + [BitArray](#qiskit.primitives.BitArray "qiskit.primitives.BitArray") + + **Raises** + + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `axes` don’t match this bit array. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `axes` includes any indices that are out of bounds. + diff --git a/docs/api/qiskit/qiskit.primitives.DataBin.mdx b/docs/api/qiskit/qiskit.primitives.DataBin.mdx index 224e4fdf5e4..50f10daa576 100644 --- a/docs/api/qiskit/qiskit.primitives.DataBin.mdx +++ b/docs/api/qiskit/qiskit.primitives.DataBin.mdx @@ -8,11 +8,75 @@ python_api_name: qiskit.primitives.DataBin # DataBin - - Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + + Bases: `ShapedMixin` - Base class for data bin containers. + Namespace for storing data. - Subclasses are typically made via `make_data_bin`, which is a specialization of `make_dataclass`. + ```python + data = DataBin( + alpha=BitArray.from_bitstrings(["0010"]), + beta=np.array([1.2]) + ) + + print("alpha data:", data.alpha) + print("beta data:", data.beta) + ``` + + **Parameters** + + * **data** – Name/value data to place in the data bin. + * **shape** (*ShapeInput*) – The leading shape common to all entries in the data bin. This defaults to the trivial leading shape of `()` that is compatible with all objects. + + **Raises** + + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If a name overlaps with a method name on this class. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If some value is inconsistent with the provided shape. + + ## Attributes + + ### ndim + + + + ### shape + + + + ### size + + + + ## Methods + + ### items + + + Return a view of field names and values + + **Return type** + + [*ItemsView*](https://docs.python.org/3/library/typing.html#typing.ItemsView "(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)")] + + + ### keys + + + Return a view of field names. + + **Return type** + + [*KeysView*](https://docs.python.org/3/library/typing.html#typing.KeysView "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + + + ### values + + + Return a view of values. + + **Return type** + + [*ValuesView*](https://docs.python.org/3/library/typing.html#typing.ValuesView "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")] + diff --git a/docs/api/qiskit/qiskit.primitives.Estimator.mdx b/docs/api/qiskit/qiskit.primitives.Estimator.mdx index dfc20b7599c..4a06e98ff0e 100644 --- a/docs/api/qiskit/qiskit.primitives.Estimator.mdx +++ b/docs/api/qiskit/qiskit.primitives.Estimator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.Estimator # Estimator - + Bases: [`BaseEstimatorV1`](qiskit.primitives.BaseEstimatorV1 "qiskit.primitives.base.base_estimator.BaseEstimatorV1")\[[`PrimitiveJob`](qiskit.primitives.PrimitiveJob "qiskit.primitives.primitive_job.PrimitiveJob")\[[`EstimatorResult`](qiskit.primitives.EstimatorResult "qiskit.primitives.base.estimator_result.EstimatorResult")]] Reference implementation of [`BaseEstimator`](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator"). @@ -42,7 +42,7 @@ python_api_name: qiskit.primitives.Estimator ### run - + 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 @@ -86,7 +86,7 @@ python_api_name: qiskit.primitives.Estimator ### set\_options - + Set options values for the estimator. **Parameters** diff --git a/docs/api/qiskit/qiskit.primitives.EstimatorResult.mdx b/docs/api/qiskit/qiskit.primitives.EstimatorResult.mdx index be128ea68c6..4a6e696a2a7 100644 --- a/docs/api/qiskit/qiskit.primitives.EstimatorResult.mdx +++ b/docs/api/qiskit/qiskit.primitives.EstimatorResult.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.EstimatorResult # EstimatorResult - + Bases: `_BasePrimitiveResult` Result of Estimator. diff --git a/docs/api/qiskit/qiskit.primitives.PrimitiveJob.mdx b/docs/api/qiskit/qiskit.primitives.PrimitiveJob.mdx index db830d70b9c..dba5c71d0f3 100644 --- a/docs/api/qiskit/qiskit.primitives.PrimitiveJob.mdx +++ b/docs/api/qiskit/qiskit.primitives.PrimitiveJob.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.PrimitiveJob # PrimitiveJob - + Bases: [`BasePrimitiveJob`](qiskit.primitives.BasePrimitiveJob "qiskit.primitives.base.base_primitive_job.BasePrimitiveJob")\[`ResultT`, [`JobStatus`](qiskit.providers.JobStatus "qiskit.providers.jobstatus.JobStatus")] Primitive job class for the reference implementations of Primitives. @@ -21,13 +21,13 @@ python_api_name: qiskit.primitives.PrimitiveJob ### cancel - + Attempt to cancel the job. ### cancelled - + Return whether the job has been cancelled. **Return type** @@ -37,7 +37,7 @@ python_api_name: qiskit.primitives.PrimitiveJob ### done - + Return whether the job has successfully run. **Return type** @@ -47,7 +47,7 @@ python_api_name: qiskit.primitives.PrimitiveJob ### in\_final\_state - + Return whether the job is in a final job state such as `DONE` or `ERROR`. **Return type** @@ -57,7 +57,7 @@ python_api_name: qiskit.primitives.PrimitiveJob ### job\_id - + Return a unique id identifying the job. **Return type** @@ -67,7 +67,7 @@ python_api_name: qiskit.primitives.PrimitiveJob ### result - + Return the results of the job. **Return type** @@ -77,7 +77,7 @@ python_api_name: qiskit.primitives.PrimitiveJob ### running - + Return whether the job is actively running. **Return type** @@ -87,7 +87,7 @@ python_api_name: qiskit.primitives.PrimitiveJob ### status - + Return the status of the job. **Return type** diff --git a/docs/api/qiskit/qiskit.primitives.PrimitiveResult.mdx b/docs/api/qiskit/qiskit.primitives.PrimitiveResult.mdx index 386128a7a14..218a94459fe 100644 --- a/docs/api/qiskit/qiskit.primitives.PrimitiveResult.mdx +++ b/docs/api/qiskit/qiskit.primitives.PrimitiveResult.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.PrimitiveResult # PrimitiveResult - + Bases: [`Generic`](https://docs.python.org/3/library/typing.html#typing.Generic "(in Python v3.12)")\[`T`] A container for multiple pub results and global metadata. diff --git a/docs/api/qiskit/qiskit.primitives.PubResult.mdx b/docs/api/qiskit/qiskit.primitives.PubResult.mdx index 9797236055c..095d367f8c8 100644 --- a/docs/api/qiskit/qiskit.primitives.PubResult.mdx +++ b/docs/api/qiskit/qiskit.primitives.PubResult.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.PubResult # PubResult - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Result of Primitive Unified Bloc. diff --git a/docs/api/qiskit/qiskit.primitives.Sampler.mdx b/docs/api/qiskit/qiskit.primitives.Sampler.mdx index 4a1d3693690..2309b5effd8 100644 --- a/docs/api/qiskit/qiskit.primitives.Sampler.mdx +++ b/docs/api/qiskit/qiskit.primitives.Sampler.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.Sampler # Sampler - + Bases: [`BaseSamplerV1`](qiskit.primitives.BaseSamplerV1 "qiskit.primitives.base.base_sampler.BaseSamplerV1")\[[`PrimitiveJob`](qiskit.primitives.PrimitiveJob "qiskit.primitives.primitive_job.PrimitiveJob")\[[`SamplerResult`](qiskit.primitives.SamplerResult "qiskit.primitives.base.sampler_result.SamplerResult")]] Sampler class. @@ -44,7 +44,7 @@ python_api_name: qiskit.primitives.Sampler ### run - + Run the job of the sampling of bitstrings. **Parameters** @@ -68,7 +68,7 @@ python_api_name: qiskit.primitives.Sampler ### set\_options - + Set options values for the estimator. **Parameters** diff --git a/docs/api/qiskit/qiskit.primitives.SamplerPubResult.mdx b/docs/api/qiskit/qiskit.primitives.SamplerPubResult.mdx new file mode 100644 index 00000000000..d88dc4077bd --- /dev/null +++ b/docs/api/qiskit/qiskit.primitives.SamplerPubResult.mdx @@ -0,0 +1,65 @@ +--- +title: SamplerPubResult +description: API reference for qiskit.primitives.SamplerPubResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.SamplerPubResult +--- + +# SamplerPubResult + + + Bases: [`PubResult`](qiskit.primitives.PubResult "qiskit.primitives.containers.pub_result.PubResult") + + Result of Sampler Pub. + + Initialize a pub result. + + **Parameters** + + * **data** ([*DataBin*](qiskit.primitives.DataBin "qiskit.primitives.DataBin")) – Result data. + * **metadata** ([*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*) – Metadata specific to this pub. Keys are expected to be strings. + + ## Attributes + + ### data + + + Result data for the pub. + + + ### metadata + + + Metadata for the pub. + + + ## Methods + + ### join\_data + + + Join data from many registers into one data container. + + Data is joined along the bits axis. For example, for [`BitArray`](qiskit.primitives.BitArray "qiskit.primitives.BitArray") data, this corresponds to bitstring concatenation. + + **Parameters** + + **names** (*Iterable\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | None*) – Which registers to join. Their order is maintained, for example, given `["alpha", "beta"]`, the data from register `alpha` is placed to the left of the data from register `beta`. When `None` is given, this value is set to the ordered list of register names, which will have been preserved from the input circuit order. + + **Returns** + + Joint data. + + **Raises** + + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If specified names are empty. + * [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If specified name does not exist. + * [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If specified data comes from incompatible types. + + **Return type** + + [BitArray](qiskit.primitives.BitArray "qiskit.primitives.BitArray") | np.ndarray + + + diff --git a/docs/api/qiskit/qiskit.primitives.SamplerResult.mdx b/docs/api/qiskit/qiskit.primitives.SamplerResult.mdx index 68522a1e805..8700c64edab 100644 --- a/docs/api/qiskit/qiskit.primitives.SamplerResult.mdx +++ b/docs/api/qiskit/qiskit.primitives.SamplerResult.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.SamplerResult # SamplerResult - + Bases: `_BasePrimitiveResult` Result of Sampler. diff --git a/docs/api/qiskit/qiskit.primitives.Shaped.mdx b/docs/api/qiskit/qiskit.primitives.Shaped.mdx new file mode 100644 index 00000000000..59f0a4636ee --- /dev/null +++ b/docs/api/qiskit/qiskit.primitives.Shaped.mdx @@ -0,0 +1,38 @@ +--- +title: Shaped +description: API reference for qiskit.primitives.Shaped +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.Shaped +--- + +# Shaped + + + Bases: [`Protocol`](https://docs.python.org/3/library/typing.html#typing.Protocol "(in Python v3.12)") + + Protocol that defines what it means to be a shaped object. + + Note that static type checkers will classify `numpy.ndarray` as being [`Shaped`](#qiskit.primitives.Shaped "qiskit.primitives.Shaped"). Moreover, since this protocol is runtime-checkable, we will even have `isinstance(, Shaped) == True`. + + ## Attributes + + ### ndim + + + The number of array dimensions of this object. + + + ### shape + + + The array shape of this object. + + + ### size + + + The total dimension of this object, i.e. the product of the entries of [`shape`](#qiskit.primitives.Shaped.shape "qiskit.primitives.Shaped.shape"). + + + diff --git a/docs/api/qiskit/qiskit.primitives.StatevectorEstimator.mdx b/docs/api/qiskit/qiskit.primitives.StatevectorEstimator.mdx index 859c556452f..18a30bb34d5 100644 --- a/docs/api/qiskit/qiskit.primitives.StatevectorEstimator.mdx +++ b/docs/api/qiskit/qiskit.primitives.StatevectorEstimator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.StatevectorEstimator # StatevectorEstimator - + Bases: [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.base.base_estimator.BaseEstimatorV2") Simple implementation of [`BaseEstimatorV2`](qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") with full state vector simulation. @@ -101,7 +101,7 @@ python_api_name: qiskit.primitives.StatevectorEstimator ### run - + Estimate expectation values for each provided pub (Primitive Unified Bloc). **Parameters** diff --git a/docs/api/qiskit/qiskit.primitives.StatevectorSampler.mdx b/docs/api/qiskit/qiskit.primitives.StatevectorSampler.mdx index 59c9ea20d0c..f85d8de4298 100644 --- a/docs/api/qiskit/qiskit.primitives.StatevectorSampler.mdx +++ b/docs/api/qiskit/qiskit.primitives.StatevectorSampler.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.primitives.StatevectorSampler # StatevectorSampler - + Bases: [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.base.base_sampler.BaseSamplerV2") Simple implementation of [`BaseSamplerV2`](qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") using full state vector simulation. @@ -108,7 +108,7 @@ python_api_name: qiskit.primitives.StatevectorSampler ### run - + Run and collect samples from each pub. **Parameters** @@ -122,7 +122,7 @@ python_api_name: qiskit.primitives.StatevectorSampler **Return type** - [PrimitiveJob](qiskit.primitives.PrimitiveJob "qiskit.primitives.PrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[[PubResult](qiskit.primitives.PubResult "qiskit.primitives.PubResult")]] + [PrimitiveJob](qiskit.primitives.PrimitiveJob "qiskit.primitives.PrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[[SamplerPubResult](qiskit.primitives.SamplerPubResult "qiskit.primitives.SamplerPubResult")]] diff --git a/docs/api/qiskit/qiskit.providers.Backend.mdx b/docs/api/qiskit/qiskit.providers.Backend.mdx index d24e1237652..bddc364206d 100644 --- a/docs/api/qiskit/qiskit.providers.Backend.mdx +++ b/docs/api/qiskit/qiskit.providers.Backend.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.Backend # Backend - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Base common type for all versioned Backend abstract classes. diff --git a/docs/api/qiskit/qiskit.providers.BackendV1.mdx b/docs/api/qiskit/qiskit.providers.BackendV1.mdx index 1861e7190df..c693aa23d41 100644 --- a/docs/api/qiskit/qiskit.providers.BackendV1.mdx +++ b/docs/api/qiskit/qiskit.providers.BackendV1.mdx @@ -8,12 +8,12 @@ python_api_name: qiskit.providers.BackendV1 # BackendV1 - + 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 abstract class is to be used for Backend objects. 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. @@ -21,7 +21,7 @@ python_api_name: qiskit.providers.BackendV1 ### \_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. @@ -51,7 +51,7 @@ python_api_name: qiskit.providers.BackendV1 In addition to the public abstract methods, subclasses should also implement the following private methods: - + 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. @@ -85,7 +85,7 @@ python_api_name: qiskit.providers.BackendV1 ### configuration - + Return the backend configuration. **Returns** @@ -99,7 +99,7 @@ python_api_name: qiskit.providers.BackendV1 ### name - + Return the backend name. **Returns** @@ -113,7 +113,7 @@ python_api_name: qiskit.providers.BackendV1 ### properties - + Return the backend properties. **Returns** @@ -127,7 +127,7 @@ python_api_name: qiskit.providers.BackendV1 ### provider - + Return the backend Provider. **Returns** @@ -141,7 +141,7 @@ python_api_name: qiskit.providers.BackendV1 ### run - + 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. @@ -162,7 +162,7 @@ python_api_name: qiskit.providers.BackendV1 ### set\_options - + 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. @@ -178,7 +178,7 @@ python_api_name: qiskit.providers.BackendV1 ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.BackendV2.mdx b/docs/api/qiskit/qiskit.providers.BackendV2.mdx index 0e6db3a3d61..487186702e4 100644 --- a/docs/api/qiskit/qiskit.providers.BackendV2.mdx +++ b/docs/api/qiskit/qiskit.providers.BackendV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.BackendV2 # BackendV2 - + 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 @@ -25,7 +25,7 @@ python_api_name: qiskit.providers.BackendV2 ### \_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. @@ -214,7 +214,7 @@ python_api_name: qiskit.providers.BackendV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -234,7 +234,7 @@ python_api_name: qiskit.providers.BackendV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -260,7 +260,7 @@ python_api_name: qiskit.providers.BackendV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -280,7 +280,7 @@ python_api_name: qiskit.providers.BackendV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -300,7 +300,7 @@ python_api_name: qiskit.providers.BackendV2 ### qubit\_properties - + 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. @@ -324,7 +324,7 @@ python_api_name: qiskit.providers.BackendV2 ### run - + 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. @@ -345,7 +345,7 @@ python_api_name: qiskit.providers.BackendV2 ### set\_options - + 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. diff --git a/docs/api/qiskit/qiskit.providers.BackendV2Converter.mdx b/docs/api/qiskit/qiskit.providers.BackendV2Converter.mdx index 6295c6a0aea..72abbdb8372 100644 --- a/docs/api/qiskit/qiskit.providers.BackendV2Converter.mdx +++ b/docs/api/qiskit/qiskit.providers.BackendV2Converter.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.BackendV2Converter # BackendV2Converter - + 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. @@ -32,7 +32,7 @@ python_api_name: qiskit.providers.BackendV2Converter * **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 + * **add\_delay** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If set to true a [`Delay`](circuit#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 @@ -167,7 +167,7 @@ python_api_name: qiskit.providers.BackendV2Converter ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -187,7 +187,7 @@ python_api_name: qiskit.providers.BackendV2Converter ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -213,7 +213,7 @@ python_api_name: qiskit.providers.BackendV2Converter ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -233,7 +233,7 @@ python_api_name: qiskit.providers.BackendV2Converter ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -253,7 +253,7 @@ python_api_name: qiskit.providers.BackendV2Converter ### qubit\_properties - + 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. @@ -277,7 +277,7 @@ python_api_name: qiskit.providers.BackendV2Converter ### run - + 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. @@ -298,7 +298,7 @@ python_api_name: qiskit.providers.BackendV2Converter ### set\_options - + 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. diff --git a/docs/api/qiskit/qiskit.providers.Job.mdx b/docs/api/qiskit/qiskit.providers.Job.mdx index 7a7520114c1..f1c1b04ffcf 100644 --- a/docs/api/qiskit/qiskit.providers.Job.mdx +++ b/docs/api/qiskit/qiskit.providers.Job.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.Job # Job - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Base common type for all versioned Job abstract classes. diff --git a/docs/api/qiskit/qiskit.providers.JobStatus.mdx b/docs/api/qiskit/qiskit.providers.JobStatus.mdx index d6cd805a450..31bbdeef588 100644 --- a/docs/api/qiskit/qiskit.providers.JobStatus.mdx +++ b/docs/api/qiskit/qiskit.providers.JobStatus.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.JobStatus # JobStatus - + Bases: [`Enum`](https://docs.python.org/3/library/enum.html#enum.Enum "(in Python v3.12)") Class for job status enumerated type. diff --git a/docs/api/qiskit/qiskit.providers.JobV1.mdx b/docs/api/qiskit/qiskit.providers.JobV1.mdx index d57a09a6d00..86b5640f885 100644 --- a/docs/api/qiskit/qiskit.providers.JobV1.mdx +++ b/docs/api/qiskit/qiskit.providers.JobV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.JobV1 # JobV1 - + 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 @@ -33,7 +33,7 @@ python_api_name: qiskit.providers.JobV1 ### backend - + Return the backend where this job was executed. **Return type** @@ -43,13 +43,13 @@ python_api_name: qiskit.providers.JobV1 ### cancel - + Attempt to cancel the job. ### cancelled - + Return whether the job has been cancelled. **Return type** @@ -59,7 +59,7 @@ python_api_name: qiskit.providers.JobV1 ### done - + Return whether the job has successfully run. **Return type** @@ -69,7 +69,7 @@ python_api_name: qiskit.providers.JobV1 ### in\_final\_state - + Return whether the job is in a final job state such as `DONE` or `ERROR`. **Return type** @@ -79,7 +79,7 @@ python_api_name: qiskit.providers.JobV1 ### job\_id - + Return a unique id identifying the job. **Return type** @@ -89,7 +89,7 @@ python_api_name: qiskit.providers.JobV1 ### result - + Return the results of the job. **Return type** @@ -99,7 +99,7 @@ python_api_name: qiskit.providers.JobV1 ### running - + Return whether the job is actively running. **Return type** @@ -109,7 +109,7 @@ python_api_name: qiskit.providers.JobV1 ### status - + Return the status of the job, among the values of `JobStatus`. **Return type** @@ -119,13 +119,13 @@ python_api_name: qiskit.providers.JobV1 ### submit - + Submit the job to the backend for execution. ### wait\_for\_final\_state - + Poll the job status until it progresses to a final state such as `DONE` or `ERROR`. **Parameters** diff --git a/docs/api/qiskit/qiskit.providers.Options.mdx b/docs/api/qiskit/qiskit.providers.Options.mdx index 1ddcdac534b..7ada83881ff 100644 --- a/docs/api/qiskit/qiskit.providers.Options.mdx +++ b/docs/api/qiskit/qiskit.providers.Options.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.Options # Options - + Bases: [`Mapping`](https://docs.python.org/3/library/collections.abc.html#collections.abc.Mapping "(in Python v3.12)") Base options object @@ -75,7 +75,7 @@ python_api_name: qiskit.providers.Options ### set\_validator - + 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: @@ -100,7 +100,7 @@ python_api_name: qiskit.providers.Options ### update\_options - + Update options with kwargs diff --git a/docs/api/qiskit/qiskit.providers.Provider.mdx b/docs/api/qiskit/qiskit.providers.Provider.mdx index 66c35d44047..56d5637adb0 100644 --- a/docs/api/qiskit/qiskit.providers.Provider.mdx +++ b/docs/api/qiskit/qiskit.providers.Provider.mdx @@ -8,13 +8,17 @@ python_api_name: qiskit.providers.Provider # Provider - + 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. + + The class `qiskit.providers.provider.Provider` is deprecated as of qiskit 1.1. It will be removed no earlier than 3 months after the release date. The abstract Provider and ProviderV1 classes are deprecated and will be removed in 2.0. You can just remove it as the parent class and a get\_backend method that returns the backends from self.backend. + + ## Attributes ### version diff --git a/docs/api/qiskit/qiskit.providers.ProviderV1.mdx b/docs/api/qiskit/qiskit.providers.ProviderV1.mdx index 98ccf88ad2b..d88e38379c9 100644 --- a/docs/api/qiskit/qiskit.providers.ProviderV1.mdx +++ b/docs/api/qiskit/qiskit.providers.ProviderV1.mdx @@ -8,11 +8,15 @@ python_api_name: qiskit.providers.ProviderV1 # ProviderV1 - + 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. + + The class `qiskit.providers.provider.Provider` is deprecated as of qiskit 1.1. It will be removed no earlier than 3 months after the release date. The abstract Provider and ProviderV1 classes are deprecated and will be removed in 2.0. You can just remove it as the parent class and a get\_backend method that returns the backends from self.backend. + + ## Attributes ### version @@ -23,7 +27,7 @@ python_api_name: qiskit.providers.ProviderV1 ### backends - + Return a list of backends matching the specified filtering. **Parameters** @@ -44,9 +48,13 @@ python_api_name: qiskit.providers.ProviderV1 ### get\_backend - + Return a single backend matching the specified filtering. + + The method `qiskit.providers.provider.ProviderV1.get_backend()` is deprecated as of qiskit 1.1. It will be removed no earlier than 3 months after the release date. The abstract Provider and ProviderV1 classes are deprecated and will be removed in 2.0. You can just remove it as the parent class and a get\_backend method that returns the backends from self.backend. + + **Parameters** * **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name of the backend. diff --git a/docs/api/qiskit/qiskit.providers.QubitProperties.mdx b/docs/api/qiskit/qiskit.providers.QubitProperties.mdx index 5d9745c86dd..5900557b324 100644 --- a/docs/api/qiskit/qiskit.providers.QubitProperties.mdx +++ b/docs/api/qiskit/qiskit.providers.QubitProperties.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.QubitProperties # QubitProperties - + 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. diff --git a/docs/api/qiskit/qiskit.providers.basic_provider.BasicProvider.mdx b/docs/api/qiskit/qiskit.providers.basic_provider.BasicProvider.mdx index 7208d01b86e..2f2297cf923 100644 --- a/docs/api/qiskit/qiskit.providers.basic_provider.BasicProvider.mdx +++ b/docs/api/qiskit/qiskit.providers.basic_provider.BasicProvider.mdx @@ -8,11 +8,15 @@ python_api_name: qiskit.providers.basic_provider.BasicProvider # BasicProvider - + Bases: [`ProviderV1`](qiskit.providers.ProviderV1 "qiskit.providers.provider.ProviderV1") Provider for test simulators. + + The class `qiskit.providers.provider.Provider` is deprecated as of qiskit 1.1. It will be removed no earlier than 3 months after the release date. The abstract Provider and ProviderV1 classes are deprecated and will be removed in 2.0. You can just remove it as the parent class and a get\_backend method that returns the backends from self.backend. + + ## Attributes ### version @@ -23,7 +27,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProvider ### backends - + Return a list of backends matching the specified filtering. **Parameters** @@ -44,9 +48,13 @@ python_api_name: qiskit.providers.basic_provider.BasicProvider ### get\_backend - + Return a single backend matching the specified filtering. + + The method `qiskit.providers.provider.ProviderV1.get_backend()` is deprecated as of qiskit 1.1. It will be removed no earlier than 3 months after the release date. The abstract Provider and ProviderV1 classes are deprecated and will be removed in 2.0. You can just remove it as the parent class and a get\_backend method that returns the backends from self.backend. + + **Parameters** * **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name of the backend. diff --git a/docs/api/qiskit/qiskit.providers.basic_provider.BasicProviderError.mdx b/docs/api/qiskit/qiskit.providers.basic_provider.BasicProviderError.mdx index fe33a9c651f..eb2a3d19d40 100644 --- a/docs/api/qiskit/qiskit.providers.basic_provider.BasicProviderError.mdx +++ b/docs/api/qiskit/qiskit.providers.basic_provider.BasicProviderError.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderError # qiskit.providers.basic\_provider.BasicProviderError - + Base class for errors raised by the Basic Provider. Set the error message. diff --git a/docs/api/qiskit/qiskit.providers.basic_provider.BasicProviderJob.mdx b/docs/api/qiskit/qiskit.providers.basic_provider.BasicProviderJob.mdx index 3ec6eea0ff4..ce5c5f20186 100644 --- a/docs/api/qiskit/qiskit.providers.basic_provider.BasicProviderJob.mdx +++ b/docs/api/qiskit/qiskit.providers.basic_provider.BasicProviderJob.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob # BasicProviderJob - + Bases: [`JobV1`](qiskit.providers.JobV1 "qiskit.providers.job.JobV1") BasicProviderJob class. @@ -31,19 +31,19 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### backend - + Return the instance of the backend used for this job. ### cancel - + Attempt to cancel the job. ### cancelled - + Return whether the job has been cancelled. **Return type** @@ -53,7 +53,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### done - + Return whether the job has successfully run. **Return type** @@ -63,7 +63,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### in\_final\_state - + Return whether the job is in a final job state such as `DONE` or `ERROR`. **Return type** @@ -73,7 +73,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### job\_id - + Return a unique id identifying the job. **Return type** @@ -83,7 +83,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### result - + Get job result . **Returns** @@ -97,7 +97,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### running - + Return whether the job is actively running. **Return type** @@ -107,7 +107,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### status - + Gets the status of the job by querying the Python’s future **Returns** @@ -121,7 +121,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### submit - + Submit the job to the backend for execution. **Raises** @@ -131,7 +131,7 @@ python_api_name: qiskit.providers.basic_provider.BasicProviderJob ### wait\_for\_final\_state - + Poll the job status until it progresses to a final state such as `DONE` or `ERROR`. **Parameters** diff --git a/docs/api/qiskit/qiskit.providers.basic_provider.BasicSimulator.mdx b/docs/api/qiskit/qiskit.providers.basic_provider.BasicSimulator.mdx index caba9da8dd4..51459aa009b 100644 --- a/docs/api/qiskit/qiskit.providers.basic_provider.BasicSimulator.mdx +++ b/docs/api/qiskit/qiskit.providers.basic_provider.BasicSimulator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator # BasicSimulator - + Bases: [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.backend.BackendV2") Python implementation of a basic (non-efficient) quantum simulator. @@ -175,7 +175,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -195,7 +195,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### configuration - + Return the simulator backend configuration. **Returns** @@ -209,7 +209,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -235,7 +235,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -255,7 +255,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -275,7 +275,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### qubit\_properties - + 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. @@ -299,7 +299,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### run - + Run on the backend. **Parameters** @@ -327,14 +327,14 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ```python backend_options = { - "initial_statevector": np.array([1, 0, 0, 1j]) / np.sqrt(2), + "initial_statevector": np.array([1, 0, 0, 1j]) / math.sqrt(2), } ``` ### run\_experiment - + Run an experiment (circuit) and return a single experiment result. **Parameters** @@ -372,7 +372,7 @@ python_api_name: qiskit.providers.basic_provider.BasicSimulator ### set\_options - + 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. diff --git a/docs/api/qiskit/qiskit.providers.convert_to_target.mdx b/docs/api/qiskit/qiskit.providers.convert_to_target.mdx index 8e65c5dae49..0316a65f4de 100644 --- a/docs/api/qiskit/qiskit.providers.convert_to_target.mdx +++ b/docs/api/qiskit/qiskit.providers.convert_to_target.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.providers.convert_to_target # qiskit.providers.convert\_to\_target - + Decode transpiler target from backend data set. This function generates `` Target` `` instance from intermediate legacy objects such as [`BackendProperties`](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") and [`PulseDefaults`](qiskit.providers.models.PulseDefaults "qiskit.providers.models.PulseDefaults"). These objects are usually components of the legacy [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") model. diff --git a/docs/api/qiskit/qiskit.providers.fake_provider.Fake127QPulseV1.mdx b/docs/api/qiskit/qiskit.providers.fake_provider.Fake127QPulseV1.mdx index 7394a738793..e4d530eb9ed 100644 --- a/docs/api/qiskit/qiskit.providers.fake_provider.Fake127QPulseV1.mdx +++ b/docs/api/qiskit/qiskit.providers.fake_provider.Fake127QPulseV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.Fake127QPulseV1 # Fake127QPulseV1 - + Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") A fake **pulse** backend with the following characteristics: @@ -68,7 +68,7 @@ python_api_name: qiskit.providers.fake_provider.Fake127QPulseV1 ### configuration - + Return the backend configuration. **Returns** @@ -82,13 +82,13 @@ python_api_name: qiskit.providers.fake_provider.Fake127QPulseV1 ### defaults - + Returns a snapshot of device defaults ### name - + Return the backend name. **Returns** @@ -102,13 +102,13 @@ python_api_name: qiskit.providers.fake_provider.Fake127QPulseV1 ### properties - + Returns a snapshot of device properties ### provider - + Return the backend Provider. **Returns** @@ -122,13 +122,13 @@ python_api_name: qiskit.providers.fake_provider.Fake127QPulseV1 ### run - + Main job in simulator ### set\_options - + 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. @@ -144,7 +144,7 @@ python_api_name: qiskit.providers.fake_provider.Fake127QPulseV1 ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.fake_provider.Fake1Q.mdx b/docs/api/qiskit/qiskit.providers.fake_provider.Fake1Q.mdx index ac5979bf19f..07f87d72b47 100644 --- a/docs/api/qiskit/qiskit.providers.fake_provider.Fake1Q.mdx +++ b/docs/api/qiskit/qiskit.providers.fake_provider.Fake1Q.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.Fake1Q # Fake1Q - + Bases: [`FakeBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.fake_backend.FakeBackend") A fake 1Q backend. @@ -33,7 +33,7 @@ python_api_name: qiskit.providers.fake_provider.Fake1Q ### configuration - + Return the backend configuration. **Returns** @@ -47,7 +47,7 @@ python_api_name: qiskit.providers.fake_provider.Fake1Q ### name - + Return the backend name. **Returns** @@ -61,13 +61,13 @@ python_api_name: qiskit.providers.fake_provider.Fake1Q ### properties - + Return backend properties ### provider - + Return the backend Provider. **Returns** @@ -81,13 +81,13 @@ python_api_name: qiskit.providers.fake_provider.Fake1Q ### run - + Main job in simulator ### set\_options - + 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. @@ -103,7 +103,7 @@ python_api_name: qiskit.providers.fake_provider.Fake1Q ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.fake_provider.Fake20QV1.mdx b/docs/api/qiskit/qiskit.providers.fake_provider.Fake20QV1.mdx index f631e95c694..0498c840237 100644 --- a/docs/api/qiskit/qiskit.providers.fake_provider.Fake20QV1.mdx +++ b/docs/api/qiskit/qiskit.providers.fake_provider.Fake20QV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.Fake20QV1 # Fake20QV1 - + Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") A fake backend with the following characteristics: @@ -70,7 +70,7 @@ python_api_name: qiskit.providers.fake_provider.Fake20QV1 ### configuration - + Return the backend configuration. **Returns** @@ -84,7 +84,7 @@ python_api_name: qiskit.providers.fake_provider.Fake20QV1 ### name - + Return the backend name. **Returns** @@ -98,13 +98,13 @@ python_api_name: qiskit.providers.fake_provider.Fake20QV1 ### properties - + Returns a snapshot of device properties ### provider - + Return the backend Provider. **Returns** @@ -118,13 +118,13 @@ python_api_name: qiskit.providers.fake_provider.Fake20QV1 ### run - + Main job in simulator ### set\_options - + 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. @@ -140,7 +140,7 @@ python_api_name: qiskit.providers.fake_provider.Fake20QV1 ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.fake_provider.Fake27QPulseV1.mdx b/docs/api/qiskit/qiskit.providers.fake_provider.Fake27QPulseV1.mdx index 86f908025e0..f898402fe21 100644 --- a/docs/api/qiskit/qiskit.providers.fake_provider.Fake27QPulseV1.mdx +++ b/docs/api/qiskit/qiskit.providers.fake_provider.Fake27QPulseV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.Fake27QPulseV1 # Fake27QPulseV1 - + Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") A fake **pulse** backend with the following characteristics: @@ -80,7 +80,7 @@ python_api_name: qiskit.providers.fake_provider.Fake27QPulseV1 ### configuration - + Return the backend configuration. **Returns** @@ -94,13 +94,13 @@ python_api_name: qiskit.providers.fake_provider.Fake27QPulseV1 ### defaults - + Returns a snapshot of device defaults ### name - + Return the backend name. **Returns** @@ -114,13 +114,13 @@ python_api_name: qiskit.providers.fake_provider.Fake27QPulseV1 ### properties - + Returns a snapshot of device properties ### provider - + Return the backend Provider. **Returns** @@ -134,13 +134,13 @@ python_api_name: qiskit.providers.fake_provider.Fake27QPulseV1 ### run - + Main job in simulator ### set\_options - + 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. @@ -156,7 +156,7 @@ python_api_name: qiskit.providers.fake_provider.Fake27QPulseV1 ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.fake_provider.Fake5QV1.mdx b/docs/api/qiskit/qiskit.providers.fake_provider.Fake5QV1.mdx index 85893eda6b0..58d484bcee6 100644 --- a/docs/api/qiskit/qiskit.providers.fake_provider.Fake5QV1.mdx +++ b/docs/api/qiskit/qiskit.providers.fake_provider.Fake5QV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.Fake5QV1 # Fake5QV1 - + Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") A fake backend with the following characteristics: @@ -68,7 +68,7 @@ python_api_name: qiskit.providers.fake_provider.Fake5QV1 ### configuration - + Return the backend configuration. **Returns** @@ -82,7 +82,7 @@ python_api_name: qiskit.providers.fake_provider.Fake5QV1 ### name - + Return the backend name. **Returns** @@ -96,13 +96,13 @@ python_api_name: qiskit.providers.fake_provider.Fake5QV1 ### properties - + Returns a snapshot of device properties ### provider - + Return the backend Provider. **Returns** @@ -116,13 +116,13 @@ python_api_name: qiskit.providers.fake_provider.Fake5QV1 ### run - + Main job in simulator ### set\_options - + 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. @@ -138,7 +138,7 @@ python_api_name: qiskit.providers.fake_provider.Fake5QV1 ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.fake_provider.Fake7QPulseV1.mdx b/docs/api/qiskit/qiskit.providers.fake_provider.Fake7QPulseV1.mdx index 45da5745fcd..2aa3bde2598 100644 --- a/docs/api/qiskit/qiskit.providers.fake_provider.Fake7QPulseV1.mdx +++ b/docs/api/qiskit/qiskit.providers.fake_provider.Fake7QPulseV1.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.Fake7QPulseV1 # Fake7QPulseV1 - + Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") A fake **pulse** backend with the following characteristics: @@ -74,7 +74,7 @@ python_api_name: qiskit.providers.fake_provider.Fake7QPulseV1 ### configuration - + Return the backend configuration. **Returns** @@ -88,13 +88,13 @@ python_api_name: qiskit.providers.fake_provider.Fake7QPulseV1 ### defaults - + Returns a snapshot of device defaults ### name - + Return the backend name. **Returns** @@ -108,13 +108,13 @@ python_api_name: qiskit.providers.fake_provider.Fake7QPulseV1 ### properties - + Returns a snapshot of device properties ### provider - + Return the backend Provider. **Returns** @@ -128,13 +128,13 @@ python_api_name: qiskit.providers.fake_provider.Fake7QPulseV1 ### run - + Main job in simulator ### set\_options - + 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. @@ -150,7 +150,7 @@ python_api_name: qiskit.providers.fake_provider.Fake7QPulseV1 ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.fake_provider.FakeOpenPulse2Q.mdx b/docs/api/qiskit/qiskit.providers.fake_provider.FakeOpenPulse2Q.mdx index e4151bef0d8..80b0f4bb9ff 100644 --- a/docs/api/qiskit/qiskit.providers.fake_provider.FakeOpenPulse2Q.mdx +++ b/docs/api/qiskit/qiskit.providers.fake_provider.FakeOpenPulse2Q.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse2Q # FakeOpenPulse2Q - + 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. @@ -38,7 +38,7 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse2Q ### configuration - + Return the backend configuration. **Returns** @@ -52,13 +52,13 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse2Q ### defaults - + Return the default pulse-related settings provided by the backend (such as gate to Schedule mappings). ### name - + Return the backend name. **Returns** @@ -72,13 +72,13 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse2Q ### properties - + Return the measured characteristics of the backend. ### provider - + Return the backend Provider. **Returns** @@ -92,13 +92,13 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse2Q ### run - + Main job in simulator ### set\_options - + 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. @@ -114,7 +114,7 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse2Q ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.fake_provider.FakeOpenPulse3Q.mdx b/docs/api/qiskit/qiskit.providers.fake_provider.FakeOpenPulse3Q.mdx index 2d6f571dc70..4b6affb474b 100644 --- a/docs/api/qiskit/qiskit.providers.fake_provider.FakeOpenPulse3Q.mdx +++ b/docs/api/qiskit/qiskit.providers.fake_provider.FakeOpenPulse3Q.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse3Q # FakeOpenPulse3Q - + Bases: [`FakeBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.fake_backend.FakeBackend") Trivial extension of the FakeOpenPulse2Q. @@ -38,7 +38,7 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse3Q ### configuration - + Return the backend configuration. **Returns** @@ -52,11 +52,11 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse3Q ### defaults - + ### name - + Return the backend name. **Returns** @@ -70,13 +70,13 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse3Q ### properties - + Return backend properties ### provider - + Return the backend Provider. **Returns** @@ -90,13 +90,13 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse3Q ### run - + Main job in simulator ### set\_options - + 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. @@ -112,7 +112,7 @@ python_api_name: qiskit.providers.fake_provider.FakeOpenPulse3Q ### status - + Return the backend status. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.fake_provider.GenericBackendV2.mdx b/docs/api/qiskit/qiskit.providers.fake_provider.GenericBackendV2.mdx index c0c0da8dca9..c7d63349723 100644 --- a/docs/api/qiskit/qiskit.providers.fake_provider.GenericBackendV2.mdx +++ b/docs/api/qiskit/qiskit.providers.fake_provider.GenericBackendV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 # GenericBackendV2 - + 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. @@ -180,7 +180,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -200,7 +200,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -226,7 +226,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -246,7 +246,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -266,7 +266,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 ### qubit\_properties - + 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. @@ -290,7 +290,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 ### run - + 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. @@ -319,7 +319,7 @@ python_api_name: qiskit.providers.fake_provider.GenericBackendV2 ### set\_options - + 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. diff --git a/docs/api/qiskit/qiskit.providers.models.BackendConfiguration.mdx b/docs/api/qiskit/qiskit.providers.models.BackendConfiguration.mdx index a8fa51a694f..717b7b82657 100644 --- a/docs/api/qiskit/qiskit.providers.models.BackendConfiguration.mdx +++ b/docs/api/qiskit/qiskit.providers.models.BackendConfiguration.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.BackendConfiguration # BackendConfiguration - + Bases: [`QasmBackendConfiguration`](qiskit.providers.models.QasmBackendConfiguration "qiskit.providers.models.backendconfiguration.QasmBackendConfiguration") Backwards compat shim representing an abstract backend configuration. @@ -99,7 +99,7 @@ python_api_name: qiskit.providers.models.BackendConfiguration ### from\_dict - + Create a new GateConfig object from a dictionary. **Parameters** @@ -117,7 +117,7 @@ python_api_name: qiskit.providers.models.BackendConfiguration ### to\_dict - + Return a dictionary format representation of the GateConfig. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.models.BackendProperties.mdx b/docs/api/qiskit/qiskit.providers.models.BackendProperties.mdx index ee332a7de25..b9ee1f348cc 100644 --- a/docs/api/qiskit/qiskit.providers.models.BackendProperties.mdx +++ b/docs/api/qiskit/qiskit.providers.models.BackendProperties.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.BackendProperties # BackendProperties - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing backend properties @@ -31,19 +31,19 @@ python_api_name: qiskit.providers.models.BackendProperties ### faulty\_gates - + Return a list of faulty gates. ### faulty\_qubits - + Return a list of faulty qubits. ### frequency - + Return the frequency of the given qubit. **Parameters** @@ -61,7 +61,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### from\_dict - + Create a new BackendProperties object from a dictionary. **Parameters** @@ -79,7 +79,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### gate\_error - + Return gate error estimates from backend properties. **Parameters** @@ -98,7 +98,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### gate\_length - + Return the duration of the gate in units of seconds. **Parameters** @@ -117,7 +117,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### gate\_property - + Return the property of the given gate. **Parameters** @@ -141,7 +141,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### is\_gate\_operational - + Return the operational status of the given gate. **Parameters** @@ -160,7 +160,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### is\_qubit\_operational - + Return the operational status of the given qubit. **Parameters** @@ -178,7 +178,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### qubit\_property - + Return the property of the given qubit. **Parameters** @@ -201,7 +201,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### readout\_error - + Return the readout error of the given qubit. **Parameters** @@ -219,7 +219,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### readout\_length - + Return the readout length \[sec] of the given qubit. **Parameters** @@ -237,7 +237,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### t1 - + Return the T1 time of the given qubit. **Parameters** @@ -255,7 +255,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### t2 - + Return the T2 time of the given qubit. **Parameters** @@ -273,7 +273,7 @@ python_api_name: qiskit.providers.models.BackendProperties ### to\_dict - + Return a dictionary format representation of the BackendProperties. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.models.BackendStatus.mdx b/docs/api/qiskit/qiskit.providers.models.BackendStatus.mdx index 39facb605e0..253da30bb9d 100644 --- a/docs/api/qiskit/qiskit.providers.models.BackendStatus.mdx +++ b/docs/api/qiskit/qiskit.providers.models.BackendStatus.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.BackendStatus # BackendStatus - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing Backend Status. @@ -31,7 +31,7 @@ python_api_name: qiskit.providers.models.BackendStatus ### from\_dict - + Create a new BackendStatus object from a dictionary. **Parameters** @@ -49,7 +49,7 @@ python_api_name: qiskit.providers.models.BackendStatus ### to\_dict - + Return a dictionary format representation of the BackendStatus. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.models.Command.mdx b/docs/api/qiskit/qiskit.providers.models.Command.mdx index 63a613f8ffc..0fc6654e34b 100644 --- a/docs/api/qiskit/qiskit.providers.models.Command.mdx +++ b/docs/api/qiskit/qiskit.providers.models.Command.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.Command # Command - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing a Command. @@ -32,7 +32,7 @@ python_api_name: qiskit.providers.models.Command ### from\_dict - + Create a new Command object from a dictionary. **Parameters** @@ -50,7 +50,7 @@ python_api_name: qiskit.providers.models.Command ### to\_dict - + Return a dictionary format representation of the Command. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.models.GateConfig.mdx b/docs/api/qiskit/qiskit.providers.models.GateConfig.mdx index 273838a6e84..a973aaaa4dd 100644 --- a/docs/api/qiskit/qiskit.providers.models.GateConfig.mdx +++ b/docs/api/qiskit/qiskit.providers.models.GateConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.GateConfig # GateConfig - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing a Gate Configuration @@ -47,7 +47,7 @@ python_api_name: qiskit.providers.models.GateConfig ### from\_dict - + Create a new GateConfig object from a dictionary. **Parameters** @@ -65,7 +65,7 @@ python_api_name: qiskit.providers.models.GateConfig ### to\_dict - + Return a dictionary format representation of the GateConfig. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.models.GateProperties.mdx b/docs/api/qiskit/qiskit.providers.models.GateProperties.mdx index f123dc060b0..66b83b0e256 100644 --- a/docs/api/qiskit/qiskit.providers.models.GateProperties.mdx +++ b/docs/api/qiskit/qiskit.providers.models.GateProperties.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.GateProperties # GateProperties - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing a gate’s properties @@ -44,7 +44,7 @@ python_api_name: qiskit.providers.models.GateProperties ### from\_dict - + Create a new Gate object from a dictionary. **Parameters** @@ -62,7 +62,7 @@ python_api_name: qiskit.providers.models.GateProperties ### to\_dict - + Return a dictionary format representation of the BackendStatus. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.models.JobStatus.mdx b/docs/api/qiskit/qiskit.providers.models.JobStatus.mdx index d914dfc9c41..67ae07361ac 100644 --- a/docs/api/qiskit/qiskit.providers.models.JobStatus.mdx +++ b/docs/api/qiskit/qiskit.providers.models.JobStatus.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.JobStatus # JobStatus - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Model for JobStatus. @@ -47,7 +47,7 @@ python_api_name: qiskit.providers.models.JobStatus ### from\_dict - + Create a new JobStatus object from a dictionary. **Parameters** @@ -65,7 +65,7 @@ python_api_name: qiskit.providers.models.JobStatus ### to\_dict - + Return a dictionary format representation of the JobStatus. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.models.Nduv.mdx b/docs/api/qiskit/qiskit.providers.models.Nduv.mdx index 8ef17c890b2..5f1284ddd5e 100644 --- a/docs/api/qiskit/qiskit.providers.models.Nduv.mdx +++ b/docs/api/qiskit/qiskit.providers.models.Nduv.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.Nduv # Nduv - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing name-date-unit-value @@ -50,7 +50,7 @@ python_api_name: qiskit.providers.models.Nduv ### from\_dict - + Create a new Nduv object from a dictionary. **Parameters** @@ -68,7 +68,7 @@ python_api_name: qiskit.providers.models.Nduv ### to\_dict - + Return a dictionary format representation of the object. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.models.PulseBackendConfiguration.mdx b/docs/api/qiskit/qiskit.providers.models.PulseBackendConfiguration.mdx index 38537e2e6c7..3514a5123b9 100644 --- a/docs/api/qiskit/qiskit.providers.models.PulseBackendConfiguration.mdx +++ b/docs/api/qiskit/qiskit.providers.models.PulseBackendConfiguration.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration # PulseBackendConfiguration - + 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. @@ -83,7 +83,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### acquire - + Return the acquisition channel for the given qubit. **Raises** @@ -101,7 +101,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### control - + Return the secondary drive channel for the given qubit – typically utilized for controlling multiqubit interactions. This channel is derived from other channels. **Parameters** @@ -123,7 +123,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### describe - + 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 @@ -159,7 +159,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### drive - + Return the drive channel for the given qubit. **Raises** @@ -177,7 +177,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### from\_dict - + Create a new GateConfig object from a dictionary. **Parameters** @@ -195,7 +195,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### get\_channel\_qubits - + Return a list of indices for qubits which are operated on directly by the given `channel`. **Raises** @@ -213,7 +213,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### get\_qubit\_channels - + Return a list of channels which operate on the given `qubit`. **Raises** @@ -231,7 +231,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### measure - + Return the measure stimulus channel for the given qubit. **Raises** @@ -249,7 +249,7 @@ python_api_name: qiskit.providers.models.PulseBackendConfiguration ### to\_dict - + Return a dictionary format representation of the GateConfig. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.models.PulseDefaults.mdx b/docs/api/qiskit/qiskit.providers.models.PulseDefaults.mdx index e10d14caff6..deb6583c28a 100644 --- a/docs/api/qiskit/qiskit.providers.models.PulseDefaults.mdx +++ b/docs/api/qiskit/qiskit.providers.models.PulseDefaults.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.PulseDefaults # PulseDefaults - + 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. @@ -33,7 +33,7 @@ python_api_name: qiskit.providers.models.PulseDefaults ### from\_dict - + Create a new PulseDefaults object from a dictionary. **Parameters** @@ -51,7 +51,7 @@ python_api_name: qiskit.providers.models.PulseDefaults ### 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/qiskit.providers.models.QasmBackendConfiguration.mdx b/docs/api/qiskit/qiskit.providers.models.QasmBackendConfiguration.mdx index 6e2ae023c82..09c8ba803c5 100644 --- a/docs/api/qiskit/qiskit.providers.models.QasmBackendConfiguration.mdx +++ b/docs/api/qiskit/qiskit.providers.models.QasmBackendConfiguration.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.QasmBackendConfiguration # QasmBackendConfiguration - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing an OpenQASM 2.0 Backend Configuration. @@ -165,7 +165,7 @@ python_api_name: qiskit.providers.models.QasmBackendConfiguration ### from\_dict - + Create a new GateConfig object from a dictionary. **Parameters** @@ -183,7 +183,7 @@ python_api_name: qiskit.providers.models.QasmBackendConfiguration ### to\_dict - + Return a dictionary format representation of the GateConfig. **Returns** diff --git a/docs/api/qiskit/qiskit.providers.models.UchannelLO.mdx b/docs/api/qiskit/qiskit.providers.models.UchannelLO.mdx index 6350389b07a..58878f8dd01 100644 --- a/docs/api/qiskit/qiskit.providers.models.UchannelLO.mdx +++ b/docs/api/qiskit/qiskit.providers.models.UchannelLO.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.providers.models.UchannelLO # UchannelLO - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class representing a U Channel LO @@ -40,7 +40,7 @@ python_api_name: qiskit.providers.models.UchannelLO ### from\_dict - + Create a new UchannelLO object from a dictionary. **Parameters** @@ -58,7 +58,7 @@ python_api_name: qiskit.providers.models.UchannelLO ### to\_dict - + Return a dictionary format representation of the UChannelLO. **Returns** diff --git a/docs/api/qiskit/qiskit.pulse.InstructionScheduleMap.mdx b/docs/api/qiskit/qiskit.pulse.InstructionScheduleMap.mdx index 13041fad5fc..319e1a14886 100644 --- a/docs/api/qiskit/qiskit.pulse.InstructionScheduleMap.mdx +++ b/docs/api/qiskit/qiskit.pulse.InstructionScheduleMap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap # InstructionScheduleMap - + 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: @@ -41,7 +41,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### add - + Add a new known instruction for the given qubits and its mapping to a pulse schedule. **Parameters** @@ -58,7 +58,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### assert\_has - + Error if the given instruction is not defined. **Parameters** @@ -73,7 +73,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### get - + 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. @@ -96,7 +96,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### get\_parameters - + Return the list of parameters taken by the given instruction on the given qubits. **Parameters** @@ -115,7 +115,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### has - + Is the instruction defined for the given qubits? **Parameters** @@ -134,7 +134,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### has\_custom\_gate - + Return `True` if the map has user provided instruction. **Return type** @@ -144,7 +144,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### pop - + Remove and return the defined schedule for the given instruction on the given qubits. **Parameters** @@ -165,7 +165,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### qubit\_instructions - + Return a list of the instruction names that are defined by the backend for the given qubit or qubits. **Parameters** @@ -185,7 +185,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### qubits\_with\_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** @@ -207,7 +207,7 @@ python_api_name: qiskit.pulse.InstructionScheduleMap ### remove - + Remove the given instruction from the listing of instructions defined in self. **Parameters** diff --git a/docs/api/qiskit/qiskit.pulse.Schedule.mdx b/docs/api/qiskit/qiskit.pulse.Schedule.mdx index 4ee5d33fc52..02d17e02e1f 100644 --- a/docs/api/qiskit/qiskit.pulse.Schedule.mdx +++ b/docs/api/qiskit/qiskit.pulse.Schedule.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.Schedule # Schedule - + 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. @@ -148,7 +148,7 @@ python_api_name: qiskit.pulse.Schedule ### append - + Return a new schedule with `schedule` inserted at the maximum time over all channels shared between `self` and `schedule`. $$ @@ -169,12 +169,14 @@ $$ ### assign\_parameters - + Assign the parameters in this schedule according to the input. **Parameters** - * **value\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*qiskit.circuit.parameterexpression.ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*Union*](https://docs.python.org/3/library/typing.html#typing.Union "(in Python v3.12)")*\[*[*qiskit.circuit.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. + * **value\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *|*[*ParameterVector*](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, ParameterValueType | Sequence\[ParameterValueType]]*) – A mapping from parameters or parameter names (parameter vector + * **values** (*or parameter vector name) to either numeric*) – + * **expression** (*or another parameter*) – * **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** @@ -183,12 +185,12 @@ $$ **Return type** - [*Schedule*](#qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + [Schedule](#qiskit.pulse.Schedule "qiskit.pulse.Schedule") ### ch\_duration - + Return the time of the end of the last instruction over the supplied channels. **Parameters** @@ -202,7 +204,7 @@ $$ ### ch\_start\_time - + Return the time of the start of the first instruction over the supplied channels. **Parameters** @@ -216,7 +218,7 @@ $$ ### ch\_stop\_time - + Return maximum start time over supplied channels. **Parameters** @@ -230,7 +232,7 @@ $$ ### draw - + Plot the schedule. **Parameters** @@ -239,9 +241,9 @@ $$ * **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/stdtypes.html#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\_range** ([*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)")*,* [*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. + * **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/stdtypes.html#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. @@ -251,7 +253,7 @@ $$ * **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. + * **plot\_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)")) – @@ -267,6 +269,8 @@ $$ * **axis** (*Any | 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. + * **show\_barrier** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – DEPRECATED. Show barrier lines. + **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. @@ -274,7 +278,7 @@ $$ ### exclude - + 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 @@ -297,7 +301,7 @@ $$ ### filter - + 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. @@ -318,7 +322,7 @@ $$ ### get\_parameters - + 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. @@ -338,7 +342,7 @@ $$ ### initialize\_from - + Create new schedule object with metadata of another schedule object. **Parameters** @@ -361,7 +365,7 @@ $$ ### insert - + Return a new schedule with `schedule` inserted into `self` at `start_time`. **Parameters** @@ -378,7 +382,7 @@ $$ ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -388,7 +392,7 @@ $$ ### replace - + Return a `Schedule` with the `old` instruction replaced with a `new` instruction. The replacement matching is based on an instruction equality check. @@ -447,7 +451,7 @@ $$ ### shift - + Return a schedule shifted forward by `time`. **Parameters** diff --git a/docs/api/qiskit/qiskit.pulse.ScheduleBlock.mdx b/docs/api/qiskit/qiskit.pulse.ScheduleBlock.mdx index 654caa27b85..7c49a019272 100644 --- a/docs/api/qiskit/qiskit.pulse.ScheduleBlock.mdx +++ b/docs/api/qiskit/qiskit.pulse.ScheduleBlock.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.ScheduleBlock # ScheduleBlock - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Time-ordered sequence of instructions with alignment context. @@ -200,7 +200,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### append - + 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** @@ -224,12 +224,14 @@ python_api_name: qiskit.pulse.ScheduleBlock ### assign\_parameters - + Assign the parameters in this schedule according to the input. **Parameters** - * **value\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*qiskit.circuit.parameterexpression.ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*Union*](https://docs.python.org/3/library/typing.html#typing.Union "(in Python v3.12)")*\[*[*qiskit.circuit.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. + * **value\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") *|*[*ParameterVector*](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, ParameterValueType | Sequence\[ParameterValueType]]*) – A mapping from parameters or parameter names (parameter vector + * **values** (*or parameter vector name) to either numeric*) – + * **expression** (*or another parameter*) – * **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** @@ -242,12 +244,12 @@ python_api_name: qiskit.pulse.ScheduleBlock **Return type** - [*ScheduleBlock*](#qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") + [ScheduleBlock](#qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") ### assign\_references - + 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: @@ -305,7 +307,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### ch\_duration - + Return the time of the end of the last instruction over the supplied channels. **Parameters** @@ -319,7 +321,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### draw - + Plot the schedule. **Parameters** @@ -328,9 +330,9 @@ python_api_name: qiskit.pulse.ScheduleBlock * **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/stdtypes.html#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\_range** ([*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)")*,* [*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. + * **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/stdtypes.html#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. @@ -340,7 +342,7 @@ python_api_name: qiskit.pulse.ScheduleBlock * **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. + * **plot\_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)")) – @@ -356,6 +358,8 @@ python_api_name: qiskit.pulse.ScheduleBlock * **axis** (*Any | 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. + * **show\_barrier** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – DEPRECATED. Show barrier lines. + **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. @@ -363,7 +367,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### exclude - + 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 @@ -388,7 +392,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### filter - + 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`. @@ -411,7 +415,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### get\_parameters - + 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, @@ -449,7 +453,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### initialize\_from - + Create new schedule object with metadata of another schedule object. **Parameters** @@ -472,7 +476,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -482,7 +486,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### is\_referenced - + Return True iff the current schedule block contains reference to subroutine. **Return type** @@ -492,7 +496,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### is\_schedulable - + Return `True` if all durations are assigned. **Return type** @@ -502,7 +506,7 @@ python_api_name: qiskit.pulse.ScheduleBlock ### replace - + Return a `ScheduleBlock` with the `old` component replaced with a `new` component. **Parameters** diff --git a/docs/api/qiskit/qiskit.pulse.channels.AcquireChannel.mdx b/docs/api/qiskit/qiskit.pulse.channels.AcquireChannel.mdx index c113b108e6c..33c769b3d1a 100644 --- a/docs/api/qiskit/qiskit.pulse.channels.AcquireChannel.mdx +++ b/docs/api/qiskit/qiskit.pulse.channels.AcquireChannel.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.channels.AcquireChannel # AcquireChannel - + Bases: [`Channel`](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") Acquire channels are used to collect data. @@ -49,7 +49,7 @@ python_api_name: qiskit.pulse.channels.AcquireChannel ### is\_parameterized - + Return True iff the channel is parameterized. **Return type** diff --git a/docs/api/qiskit/qiskit.pulse.channels.ControlChannel.mdx b/docs/api/qiskit/qiskit.pulse.channels.ControlChannel.mdx index ab52ccf250d..0e8efd40652 100644 --- a/docs/api/qiskit/qiskit.pulse.channels.ControlChannel.mdx +++ b/docs/api/qiskit/qiskit.pulse.channels.ControlChannel.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.channels.ControlChannel # ControlChannel - + 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. @@ -49,7 +49,7 @@ python_api_name: qiskit.pulse.channels.ControlChannel ### is\_parameterized - + Return True iff the channel is parameterized. **Return type** diff --git a/docs/api/qiskit/qiskit.pulse.channels.DriveChannel.mdx b/docs/api/qiskit/qiskit.pulse.channels.DriveChannel.mdx index c4d03dca138..5eeb1c3a0eb 100644 --- a/docs/api/qiskit/qiskit.pulse.channels.DriveChannel.mdx +++ b/docs/api/qiskit/qiskit.pulse.channels.DriveChannel.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.channels.DriveChannel # DriveChannel - + Bases: `PulseChannel` Drive channels transmit signals to qubits which enact gate operations. @@ -49,7 +49,7 @@ python_api_name: qiskit.pulse.channels.DriveChannel ### is\_parameterized - + Return True iff the channel is parameterized. **Return type** diff --git a/docs/api/qiskit/qiskit.pulse.channels.MeasureChannel.mdx b/docs/api/qiskit/qiskit.pulse.channels.MeasureChannel.mdx index 725b2c78e13..99b70286bf5 100644 --- a/docs/api/qiskit/qiskit.pulse.channels.MeasureChannel.mdx +++ b/docs/api/qiskit/qiskit.pulse.channels.MeasureChannel.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.channels.MeasureChannel # MeasureChannel - + Bases: `PulseChannel` Measure channels transmit measurement stimulus pulses for readout. @@ -49,7 +49,7 @@ python_api_name: qiskit.pulse.channels.MeasureChannel ### is\_parameterized - + Return True iff the channel is parameterized. **Return type** diff --git a/docs/api/qiskit/qiskit.pulse.channels.MemorySlot.mdx b/docs/api/qiskit/qiskit.pulse.channels.MemorySlot.mdx index 55976dc205e..e4a2d09f114 100644 --- a/docs/api/qiskit/qiskit.pulse.channels.MemorySlot.mdx +++ b/docs/api/qiskit/qiskit.pulse.channels.MemorySlot.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.channels.MemorySlot # MemorySlot - + Bases: `ClassicalIOChannel` Memory slot channels represent classical memory storage. @@ -49,7 +49,7 @@ python_api_name: qiskit.pulse.channels.MemorySlot ### is\_parameterized - + Return True iff the channel is parameterized. **Return type** diff --git a/docs/api/qiskit/qiskit.pulse.channels.RegisterSlot.mdx b/docs/api/qiskit/qiskit.pulse.channels.RegisterSlot.mdx index 63873431818..30d635765ef 100644 --- a/docs/api/qiskit/qiskit.pulse.channels.RegisterSlot.mdx +++ b/docs/api/qiskit/qiskit.pulse.channels.RegisterSlot.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.channels.RegisterSlot # RegisterSlot - + Bases: `ClassicalIOChannel` Classical resister slot channels represent classical registers (low-latency classical memory). @@ -49,7 +49,7 @@ python_api_name: qiskit.pulse.channels.RegisterSlot ### is\_parameterized - + Return True iff the channel is parameterized. **Return type** diff --git a/docs/api/qiskit/qiskit.pulse.channels.SnapshotChannel.mdx b/docs/api/qiskit/qiskit.pulse.channels.SnapshotChannel.mdx index d1f213f0820..52c45ad58d1 100644 --- a/docs/api/qiskit/qiskit.pulse.channels.SnapshotChannel.mdx +++ b/docs/api/qiskit/qiskit.pulse.channels.SnapshotChannel.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.channels.SnapshotChannel # SnapshotChannel - + Bases: `ClassicalIOChannel` Snapshot channels are used to specify instructions for simulators. @@ -45,7 +45,7 @@ python_api_name: qiskit.pulse.channels.SnapshotChannel ### is\_parameterized - + Return True iff the channel is parameterized. **Return type** diff --git a/docs/api/qiskit/qiskit.pulse.instructions.Acquire.mdx b/docs/api/qiskit/qiskit.pulse.instructions.Acquire.mdx index 81709415b88..4b640969665 100644 --- a/docs/api/qiskit/qiskit.pulse.instructions.Acquire.mdx +++ b/docs/api/qiskit/qiskit.pulse.instructions.Acquire.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.Acquire # Acquire - + 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: @@ -127,7 +127,7 @@ python_api_name: qiskit.pulse.instructions.Acquire ### append - + 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** @@ -146,7 +146,7 @@ python_api_name: qiskit.pulse.instructions.Acquire ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -160,7 +160,7 @@ python_api_name: qiskit.pulse.instructions.Acquire ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -174,7 +174,7 @@ python_api_name: qiskit.pulse.instructions.Acquire ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -188,7 +188,7 @@ python_api_name: qiskit.pulse.instructions.Acquire ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -208,7 +208,7 @@ python_api_name: qiskit.pulse.instructions.Acquire ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -218,7 +218,7 @@ python_api_name: qiskit.pulse.instructions.Acquire ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/qiskit.pulse.instructions.Delay.mdx b/docs/api/qiskit/qiskit.pulse.instructions.Delay.mdx index 45464264077..9fe9b1a875c 100644 --- a/docs/api/qiskit/qiskit.pulse.instructions.Delay.mdx +++ b/docs/api/qiskit/qiskit.pulse.instructions.Delay.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.Delay # Delay - + 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. @@ -101,7 +101,7 @@ python_api_name: qiskit.pulse.instructions.Delay ### append - + 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** @@ -120,7 +120,7 @@ python_api_name: qiskit.pulse.instructions.Delay ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -134,7 +134,7 @@ python_api_name: qiskit.pulse.instructions.Delay ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -148,7 +148,7 @@ python_api_name: qiskit.pulse.instructions.Delay ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -162,7 +162,7 @@ python_api_name: qiskit.pulse.instructions.Delay ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -182,7 +182,7 @@ python_api_name: qiskit.pulse.instructions.Delay ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -192,7 +192,7 @@ python_api_name: qiskit.pulse.instructions.Delay ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/qiskit.pulse.instructions.Play.mdx b/docs/api/qiskit/qiskit.pulse.instructions.Play.mdx index 3a4f8134192..5f8f8d98bab 100644 --- a/docs/api/qiskit/qiskit.pulse.instructions.Play.mdx +++ b/docs/api/qiskit/qiskit.pulse.instructions.Play.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.Play # Play - + Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") This instruction is responsible for applying a pulse on a channel. @@ -95,7 +95,7 @@ python_api_name: qiskit.pulse.instructions.Play ### append - + 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** @@ -114,7 +114,7 @@ python_api_name: qiskit.pulse.instructions.Play ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -128,7 +128,7 @@ python_api_name: qiskit.pulse.instructions.Play ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -142,7 +142,7 @@ python_api_name: qiskit.pulse.instructions.Play ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -156,7 +156,7 @@ python_api_name: qiskit.pulse.instructions.Play ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -176,7 +176,7 @@ python_api_name: qiskit.pulse.instructions.Play ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -186,7 +186,7 @@ python_api_name: qiskit.pulse.instructions.Play ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/qiskit.pulse.instructions.Reference.mdx b/docs/api/qiskit/qiskit.pulse.instructions.Reference.mdx index 79baadefad3..db82289d1b2 100644 --- a/docs/api/qiskit/qiskit.pulse.instructions.Reference.mdx +++ b/docs/api/qiskit/qiskit.pulse.instructions.Reference.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.Reference # Reference - + Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") Pulse compiler directive that refers to a subroutine. @@ -100,7 +100,7 @@ python_api_name: qiskit.pulse.instructions.Reference ### append - + 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** @@ -119,7 +119,7 @@ python_api_name: qiskit.pulse.instructions.Reference ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -133,7 +133,7 @@ python_api_name: qiskit.pulse.instructions.Reference ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -147,7 +147,7 @@ python_api_name: qiskit.pulse.instructions.Reference ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -161,7 +161,7 @@ python_api_name: qiskit.pulse.instructions.Reference ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -181,7 +181,7 @@ python_api_name: qiskit.pulse.instructions.Reference ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -191,7 +191,7 @@ python_api_name: qiskit.pulse.instructions.Reference ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/qiskit.pulse.instructions.RelativeBarrier.mdx b/docs/api/qiskit/qiskit.pulse.instructions.RelativeBarrier.mdx index 5bcfc1cfa1d..a8e0c6eba8f 100644 --- a/docs/api/qiskit/qiskit.pulse.instructions.RelativeBarrier.mdx +++ b/docs/api/qiskit/qiskit.pulse.instructions.RelativeBarrier.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier # RelativeBarrier - + Bases: `Directive` Pulse `RelativeBarrier` directive. @@ -82,7 +82,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier ### append - + 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** @@ -101,7 +101,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -115,7 +115,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -129,7 +129,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -143,7 +143,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -163,7 +163,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -173,7 +173,7 @@ python_api_name: qiskit.pulse.instructions.RelativeBarrier ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/qiskit.pulse.instructions.SetFrequency.mdx b/docs/api/qiskit/qiskit.pulse.instructions.SetFrequency.mdx index b4ecd96c119..1ca693de4d5 100644 --- a/docs/api/qiskit/qiskit.pulse.instructions.SetFrequency.mdx +++ b/docs/api/qiskit/qiskit.pulse.instructions.SetFrequency.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.SetFrequency # SetFrequency - + 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 @@ -103,7 +103,7 @@ $$ ### append - + 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** @@ -122,7 +122,7 @@ $$ ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -136,7 +136,7 @@ $$ ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -150,7 +150,7 @@ $$ ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -164,7 +164,7 @@ $$ ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -184,7 +184,7 @@ $$ ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -194,7 +194,7 @@ $$ ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/qiskit.pulse.instructions.SetPhase.mdx b/docs/api/qiskit/qiskit.pulse.instructions.SetPhase.mdx index fa710abf598..937ea6b4d2c 100644 --- a/docs/api/qiskit/qiskit.pulse.instructions.SetPhase.mdx +++ b/docs/api/qiskit/qiskit.pulse.instructions.SetPhase.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.SetPhase # SetPhase - + 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. @@ -101,7 +101,7 @@ $$ ### append - + 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** @@ -120,7 +120,7 @@ $$ ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -134,7 +134,7 @@ $$ ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -148,7 +148,7 @@ $$ ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -162,7 +162,7 @@ $$ ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -182,7 +182,7 @@ $$ ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -192,7 +192,7 @@ $$ ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/qiskit.pulse.instructions.ShiftFrequency.mdx b/docs/api/qiskit/qiskit.pulse.instructions.ShiftFrequency.mdx index 00e052966fe..59a514c0b13 100644 --- a/docs/api/qiskit/qiskit.pulse.instructions.ShiftFrequency.mdx +++ b/docs/api/qiskit/qiskit.pulse.instructions.ShiftFrequency.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency # ShiftFrequency - + Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") Shift the channel frequency away from the current frequency. @@ -93,7 +93,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency ### append - + 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** @@ -112,7 +112,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -126,7 +126,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -140,7 +140,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -154,7 +154,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -174,7 +174,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -184,7 +184,7 @@ python_api_name: qiskit.pulse.instructions.ShiftFrequency ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/qiskit.pulse.instructions.ShiftPhase.mdx b/docs/api/qiskit/qiskit.pulse.instructions.ShiftPhase.mdx index 777f7af8d63..62a0d329f52 100644 --- a/docs/api/qiskit/qiskit.pulse.instructions.ShiftPhase.mdx +++ b/docs/api/qiskit/qiskit.pulse.instructions.ShiftPhase.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.ShiftPhase # ShiftPhase - + 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. @@ -105,7 +105,7 @@ $$ ### append - + 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** @@ -124,7 +124,7 @@ $$ ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -138,7 +138,7 @@ $$ ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -152,7 +152,7 @@ $$ ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -166,7 +166,7 @@ $$ ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -186,7 +186,7 @@ $$ ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -196,7 +196,7 @@ $$ ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/qiskit.pulse.instructions.Snapshot.mdx b/docs/api/qiskit/qiskit.pulse.instructions.Snapshot.mdx index 16211a6aef3..fe3ed365d3b 100644 --- a/docs/api/qiskit/qiskit.pulse.instructions.Snapshot.mdx +++ b/docs/api/qiskit/qiskit.pulse.instructions.Snapshot.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot # Snapshot - + Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") An instruction targeted for simulators, to capture a moment in the simulation. @@ -99,7 +99,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot ### append - + 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** @@ -118,7 +118,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -132,7 +132,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -146,7 +146,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -160,7 +160,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -180,7 +180,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -190,7 +190,7 @@ python_api_name: qiskit.pulse.instructions.Snapshot ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/qiskit.pulse.instructions.TimeBlockade.mdx b/docs/api/qiskit/qiskit.pulse.instructions.TimeBlockade.mdx index ef434541f25..750dd175e62 100644 --- a/docs/api/qiskit/qiskit.pulse.instructions.TimeBlockade.mdx +++ b/docs/api/qiskit/qiskit.pulse.instructions.TimeBlockade.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade # TimeBlockade - + Bases: `Directive` Pulse `TimeBlockade` directive. @@ -118,7 +118,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade ### append - + 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** @@ -137,7 +137,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade ### ch\_duration - + Return duration of the supplied channels in this Instruction. **Parameters** @@ -151,7 +151,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade ### ch\_start\_time - + Return minimum start time for supplied channels. **Parameters** @@ -165,7 +165,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade ### ch\_stop\_time - + Return maximum start time for supplied channels. **Parameters** @@ -179,7 +179,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade ### insert - + Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. **Parameters** @@ -199,7 +199,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -209,7 +209,7 @@ python_api_name: qiskit.pulse.instructions.TimeBlockade ### shift - + Return a new schedule shifted forward by time. **Parameters** diff --git a/docs/api/qiskit/qiskit.pulse.library.Constant_class.rst.mdx b/docs/api/qiskit/qiskit.pulse.library.Constant_class.rst.mdx index 334c1914df7..fdbf208985e 100644 --- a/docs/api/qiskit/qiskit.pulse.library.Constant_class.rst.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.Constant_class.rst.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.library.Constant # Constant - + 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: diff --git a/docs/api/qiskit/qiskit.pulse.library.Cos_class.rst.mdx b/docs/api/qiskit/qiskit.pulse.library.Cos_class.rst.mdx index dd046844931..205de27867c 100644 --- a/docs/api/qiskit/qiskit.pulse.library.Cos_class.rst.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.Cos_class.rst.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.Cos # qiskit.pulse.library.Cos - + A cosine pulse. The envelope of the pulse is given by: diff --git a/docs/api/qiskit/qiskit.pulse.library.Drag_class.rst.mdx b/docs/api/qiskit/qiskit.pulse.library.Drag_class.rst.mdx index b43c2be2eb6..a99ae0f1e12 100644 --- a/docs/api/qiskit/qiskit.pulse.library.Drag_class.rst.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.Drag_class.rst.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.library.Drag # Drag - + 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. diff --git a/docs/api/qiskit/qiskit.pulse.library.GaussianDeriv.mdx b/docs/api/qiskit/qiskit.pulse.library.GaussianDeriv.mdx index 5bed1103bfe..7ea0249af41 100644 --- a/docs/api/qiskit/qiskit.pulse.library.GaussianDeriv.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.GaussianDeriv.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.GaussianDeriv # qiskit.pulse.library.GaussianDeriv - + 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: diff --git a/docs/api/qiskit/qiskit.pulse.library.GaussianSquare.mdx b/docs/api/qiskit/qiskit.pulse.library.GaussianSquare.mdx index 3daf99d2a6d..6ca61d1c16b 100644 --- a/docs/api/qiskit/qiskit.pulse.library.GaussianSquare.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.GaussianSquare.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.library.GaussianSquare # GaussianSquare - + 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. diff --git a/docs/api/qiskit/qiskit.pulse.library.GaussianSquareDrag.mdx b/docs/api/qiskit/qiskit.pulse.library.GaussianSquareDrag.mdx index e074fdbc9d1..107f239ebbf 100644 --- a/docs/api/qiskit/qiskit.pulse.library.GaussianSquareDrag.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.GaussianSquareDrag.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.GaussianSquareDrag # qiskit.pulse.library.GaussianSquareDrag - + 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. diff --git a/docs/api/qiskit/qiskit.pulse.library.Gaussian_class.rst.mdx b/docs/api/qiskit/qiskit.pulse.library.Gaussian_class.rst.mdx index b8a79c509e2..4469f97e6e1 100644 --- a/docs/api/qiskit/qiskit.pulse.library.Gaussian_class.rst.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.Gaussian_class.rst.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.library.Gaussian # Gaussian - + 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): diff --git a/docs/api/qiskit/qiskit.pulse.library.Sawtooth_class.rst.mdx b/docs/api/qiskit/qiskit.pulse.library.Sawtooth_class.rst.mdx index dc380886562..73263b02f5f 100644 --- a/docs/api/qiskit/qiskit.pulse.library.Sawtooth_class.rst.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.Sawtooth_class.rst.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.Sawtooth # qiskit.pulse.library.Sawtooth - + A sawtooth pulse. The envelope of the pulse is given by: diff --git a/docs/api/qiskit/qiskit.pulse.library.SechDeriv.mdx b/docs/api/qiskit/qiskit.pulse.library.SechDeriv.mdx index 5488bf956b3..5d3d5c4f369 100644 --- a/docs/api/qiskit/qiskit.pulse.library.SechDeriv.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.SechDeriv.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.SechDeriv # qiskit.pulse.library.SechDeriv - + 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: diff --git a/docs/api/qiskit/qiskit.pulse.library.Sech_fun.rst.mdx b/docs/api/qiskit/qiskit.pulse.library.Sech_fun.rst.mdx index 29db9e8de29..b4839f7d92d 100644 --- a/docs/api/qiskit/qiskit.pulse.library.Sech_fun.rst.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.Sech_fun.rst.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.Sech # qiskit.pulse.library.Sech - + 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: diff --git a/docs/api/qiskit/qiskit.pulse.library.Sin_class.rst.mdx b/docs/api/qiskit/qiskit.pulse.library.Sin_class.rst.mdx index 6aa99386ef3..5244f517729 100644 --- a/docs/api/qiskit/qiskit.pulse.library.Sin_class.rst.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.Sin_class.rst.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.Sin # qiskit.pulse.library.Sin - + A sinusoidal pulse. The envelope of the pulse is given by: diff --git a/docs/api/qiskit/qiskit.pulse.library.Square_fun.rst.mdx b/docs/api/qiskit/qiskit.pulse.library.Square_fun.rst.mdx index 2e3cc3ace02..431a2319420 100644 --- a/docs/api/qiskit/qiskit.pulse.library.Square_fun.rst.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.Square_fun.rst.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.Square # qiskit.pulse.library.Square - + A square wave pulse. The envelope of the pulse is given by: diff --git a/docs/api/qiskit/qiskit.pulse.library.SymbolicPulse.mdx b/docs/api/qiskit/qiskit.pulse.library.SymbolicPulse.mdx index f884f907dc3..c81245392aa 100644 --- a/docs/api/qiskit/qiskit.pulse.library.SymbolicPulse.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.SymbolicPulse.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.library.SymbolicPulse # SymbolicPulse - + Bases: `Pulse` The pulse representation model with parameters and symbolic expressions. @@ -172,7 +172,7 @@ $$ ### draw - + Plot the interpolated envelope of pulse. **Parameters** @@ -208,7 +208,7 @@ $$ ### 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: @@ -233,7 +233,7 @@ $$ ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** @@ -243,7 +243,7 @@ $$ ### validate\_parameters - + Validate parameters. **Raises** diff --git a/docs/api/qiskit/qiskit.pulse.library.Triangle_class.rst.mdx b/docs/api/qiskit/qiskit.pulse.library.Triangle_class.rst.mdx index dd8cd915741..e8cd2fa4428 100644 --- a/docs/api/qiskit/qiskit.pulse.library.Triangle_class.rst.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.Triangle_class.rst.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.Triangle # qiskit.pulse.library.Triangle - + A triangle wave pulse. The envelope of the pulse is given by: diff --git a/docs/api/qiskit/qiskit.pulse.library.Waveform.mdx b/docs/api/qiskit/qiskit.pulse.library.Waveform.mdx index d0c3eeda34b..5dabdbcd5ba 100644 --- a/docs/api/qiskit/qiskit.pulse.library.Waveform.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.Waveform.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.library.Waveform # Waveform - + Bases: `Pulse` A pulse specified completely by complex-valued samples; each sample is played for the duration of the backend cycle-time, dt. @@ -58,7 +58,7 @@ python_api_name: qiskit.pulse.library.Waveform ### draw - + Plot the interpolated envelope of pulse. **Parameters** @@ -94,7 +94,7 @@ python_api_name: qiskit.pulse.library.Waveform ### is\_parameterized - + Return True iff the instruction is parameterized. **Return type** diff --git a/docs/api/qiskit/qiskit.pulse.library.gaussian_square_echo.mdx b/docs/api/qiskit/qiskit.pulse.library.gaussian_square_echo.mdx index 9db41ff7b66..8f1946ffd8c 100644 --- a/docs/api/qiskit/qiskit.pulse.library.gaussian_square_echo.mdx +++ b/docs/api/qiskit/qiskit.pulse.library.gaussian_square_echo.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.pulse.library.gaussian_square_echo # qiskit.pulse.library.gaussian\_square\_echo - + 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: diff --git a/docs/api/qiskit/qiskit.pulse.transforms.AlignEquispaced.mdx b/docs/api/qiskit/qiskit.pulse.transforms.AlignEquispaced.mdx index 566aeb3e2cf..a4e429fd9fb 100644 --- a/docs/api/qiskit/qiskit.pulse.transforms.AlignEquispaced.mdx +++ b/docs/api/qiskit/qiskit.pulse.transforms.AlignEquispaced.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.transforms.AlignEquispaced # AlignEquispaced - + Bases: [`AlignmentKind`](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") Align instructions with equispaced interval within a specified duration. @@ -37,7 +37,7 @@ python_api_name: qiskit.pulse.transforms.AlignEquispaced ### align - + Reallocate instructions according to the policy. Only top-level sub-schedules are aligned. If sub-schedules are nested, nested schedules are not recursively aligned. diff --git a/docs/api/qiskit/qiskit.pulse.transforms.AlignFunc.mdx b/docs/api/qiskit/qiskit.pulse.transforms.AlignFunc.mdx index 58d736b3947..a86309f6e18 100644 --- a/docs/api/qiskit/qiskit.pulse.transforms.AlignFunc.mdx +++ b/docs/api/qiskit/qiskit.pulse.transforms.AlignFunc.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.transforms.AlignFunc # AlignFunc - + Bases: [`AlignmentKind`](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") Allocate instructions at position specified by callback function. @@ -57,7 +57,7 @@ python_api_name: qiskit.pulse.transforms.AlignFunc ### align - + Reallocate instructions according to the policy. Only top-level sub-schedules are aligned. If sub-schedules are nested, nested schedules are not recursively aligned. diff --git a/docs/api/qiskit/qiskit.pulse.transforms.AlignLeft.mdx b/docs/api/qiskit/qiskit.pulse.transforms.AlignLeft.mdx index b66860a95c9..a035bdc1f7f 100644 --- a/docs/api/qiskit/qiskit.pulse.transforms.AlignLeft.mdx +++ b/docs/api/qiskit/qiskit.pulse.transforms.AlignLeft.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.transforms.AlignLeft # AlignLeft - + Bases: [`AlignmentKind`](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") Align instructions in as-soon-as-possible manner. @@ -27,7 +27,7 @@ python_api_name: qiskit.pulse.transforms.AlignLeft ### align - + Reallocate instructions according to the policy. Only top-level sub-schedules are aligned. If sub-schedules are nested, nested schedules are not recursively aligned. diff --git a/docs/api/qiskit/qiskit.pulse.transforms.AlignRight.mdx b/docs/api/qiskit/qiskit.pulse.transforms.AlignRight.mdx index 007abec0f59..c056ce6c1c3 100644 --- a/docs/api/qiskit/qiskit.pulse.transforms.AlignRight.mdx +++ b/docs/api/qiskit/qiskit.pulse.transforms.AlignRight.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.transforms.AlignRight # AlignRight - + Bases: [`AlignmentKind`](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") Align instructions in as-late-as-possible manner. @@ -27,7 +27,7 @@ python_api_name: qiskit.pulse.transforms.AlignRight ### align - + Reallocate instructions according to the policy. Only top-level sub-schedules are aligned. If sub-schedules are nested, nested schedules are not recursively aligned. diff --git a/docs/api/qiskit/qiskit.pulse.transforms.AlignSequential.mdx b/docs/api/qiskit/qiskit.pulse.transforms.AlignSequential.mdx index 8c93fca08d1..41195cff3d3 100644 --- a/docs/api/qiskit/qiskit.pulse.transforms.AlignSequential.mdx +++ b/docs/api/qiskit/qiskit.pulse.transforms.AlignSequential.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.pulse.transforms.AlignSequential # AlignSequential - + Bases: [`AlignmentKind`](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") Align instructions sequentially. @@ -27,7 +27,7 @@ python_api_name: qiskit.pulse.transforms.AlignSequential ### align - + Reallocate instructions according to the policy. Only top-level sub-schedules are aligned. If sub-schedules are nested, nested schedules are not recursively aligned. diff --git a/docs/api/qiskit/qiskit.qobj.GateCalibration.mdx b/docs/api/qiskit/qiskit.qobj.GateCalibration.mdx index 0dde85dcf2f..32b9447e059 100644 --- a/docs/api/qiskit/qiskit.qobj.GateCalibration.mdx +++ b/docs/api/qiskit/qiskit.qobj.GateCalibration.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.GateCalibration # GateCalibration - + 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. @@ -26,7 +26,7 @@ python_api_name: qiskit.qobj.GateCalibration ### from\_dict - + Create a new GateCalibration object from a dictionary. **Parameters** @@ -44,7 +44,7 @@ python_api_name: qiskit.qobj.GateCalibration ### to\_dict - + Return a dictionary format representation of the Gate Calibration. **Returns** diff --git a/docs/api/qiskit/qiskit.qobj.PulseLibraryItem.mdx b/docs/api/qiskit/qiskit.qobj.PulseLibraryItem.mdx index ec944a5468e..f9cce4c462f 100644 --- a/docs/api/qiskit/qiskit.qobj.PulseLibraryItem.mdx +++ b/docs/api/qiskit/qiskit.qobj.PulseLibraryItem.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.PulseLibraryItem # PulseLibraryItem - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") An item in a pulse library. @@ -24,7 +24,7 @@ python_api_name: qiskit.qobj.PulseLibraryItem ### from\_dict - + Create a new PulseLibraryItem object from a dictionary. **Parameters** @@ -42,7 +42,7 @@ python_api_name: qiskit.qobj.PulseLibraryItem ### to\_dict - + Return a dictionary format representation of the pulse library item. **Returns** diff --git a/docs/api/qiskit/qiskit.qobj.PulseQobj.mdx b/docs/api/qiskit/qiskit.qobj.PulseQobj.mdx index f47ab85e69f..30712228043 100644 --- a/docs/api/qiskit/qiskit.qobj.PulseQobj.mdx +++ b/docs/api/qiskit/qiskit.qobj.PulseQobj.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.PulseQobj # PulseQobj - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") A Pulse Qobj. @@ -28,7 +28,7 @@ python_api_name: qiskit.qobj.PulseQobj ### from\_dict - + Create a new PulseQobj object from a dictionary. **Parameters** @@ -46,7 +46,7 @@ python_api_name: qiskit.qobj.PulseQobj ### 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: diff --git a/docs/api/qiskit/qiskit.qobj.PulseQobjConfig.mdx b/docs/api/qiskit/qiskit.qobj.PulseQobjConfig.mdx index ce4c06815c9..a27663f5d8d 100644 --- a/docs/api/qiskit/qiskit.qobj.PulseQobjConfig.mdx +++ b/docs/api/qiskit/qiskit.qobj.PulseQobjConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.PulseQobjConfig # PulseQobjConfig - + Bases: `QobjDictField` A configuration for a Pulse Qobj. @@ -34,7 +34,7 @@ python_api_name: qiskit.qobj.PulseQobjConfig ### from\_dict - + Create a new PulseQobjConfig object from a dictionary. **Parameters** @@ -52,7 +52,7 @@ python_api_name: qiskit.qobj.PulseQobjConfig ### to\_dict - + Return a dictionary format representation of the Pulse Qobj config. **Returns** diff --git a/docs/api/qiskit/qiskit.qobj.PulseQobjExperiment.mdx b/docs/api/qiskit/qiskit.qobj.PulseQobjExperiment.mdx index b9a23589bea..d93cece75a3 100644 --- a/docs/api/qiskit/qiskit.qobj.PulseQobjExperiment.mdx +++ b/docs/api/qiskit/qiskit.qobj.PulseQobjExperiment.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.PulseQobjExperiment # PulseQobjExperiment - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") A Pulse Qobj Experiment. @@ -27,7 +27,7 @@ python_api_name: qiskit.qobj.PulseQobjExperiment ### from\_dict - + Create a new PulseQobjExperiment object from a dictionary. **Parameters** @@ -45,7 +45,7 @@ python_api_name: qiskit.qobj.PulseQobjExperiment ### to\_dict - + Return a dictionary format representation of the Experiment. **Returns** diff --git a/docs/api/qiskit/qiskit.qobj.PulseQobjExperimentConfig.mdx b/docs/api/qiskit/qiskit.qobj.PulseQobjExperimentConfig.mdx index b603d7e3057..b8bf493077f 100644 --- a/docs/api/qiskit/qiskit.qobj.PulseQobjExperimentConfig.mdx +++ b/docs/api/qiskit/qiskit.qobj.PulseQobjExperimentConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.PulseQobjExperimentConfig # PulseQobjExperimentConfig - + Bases: `QobjDictField` A config for a single Pulse experiment in the qobj. @@ -25,7 +25,7 @@ python_api_name: qiskit.qobj.PulseQobjExperimentConfig ### from\_dict - + Create a new QobjHeader object from a dictionary. **Parameters** @@ -43,7 +43,7 @@ python_api_name: qiskit.qobj.PulseQobjExperimentConfig ### to\_dict - + Return a dictionary format representation of the OpenQASM 2 Qobj. **Returns** diff --git a/docs/api/qiskit/qiskit.qobj.PulseQobjInstruction.mdx b/docs/api/qiskit/qiskit.qobj.PulseQobjInstruction.mdx index 307a36a6763..dc380509210 100644 --- a/docs/api/qiskit/qiskit.qobj.PulseQobjInstruction.mdx +++ b/docs/api/qiskit/qiskit.qobj.PulseQobjInstruction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.PulseQobjInstruction # PulseQobjInstruction - + 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. @@ -39,7 +39,7 @@ python_api_name: qiskit.qobj.PulseQobjInstruction ### from\_dict - + Create a new PulseQobjExperimentConfig object from a dictionary. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.qobj.PulseQobjInstruction ### to\_dict - + Return a dictionary format representation of the Instruction. **Returns** diff --git a/docs/api/qiskit/qiskit.qobj.QasmExperimentCalibrations.mdx b/docs/api/qiskit/qiskit.qobj.QasmExperimentCalibrations.mdx index f21c88e7cfe..9efe1f5ef33 100644 --- a/docs/api/qiskit/qiskit.qobj.QasmExperimentCalibrations.mdx +++ b/docs/api/qiskit/qiskit.qobj.QasmExperimentCalibrations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QasmExperimentCalibrations # QasmExperimentCalibrations - + 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. @@ -23,7 +23,7 @@ python_api_name: qiskit.qobj.QasmExperimentCalibrations ### from\_dict - + Create a new GateCalibration object from a dictionary. **Parameters** @@ -41,7 +41,7 @@ python_api_name: qiskit.qobj.QasmExperimentCalibrations ### to\_dict - + Return a dictionary format representation of the calibrations. **Returns** diff --git a/docs/api/qiskit/qiskit.qobj.QasmQobj.mdx b/docs/api/qiskit/qiskit.qobj.QasmQobj.mdx index 73c9e8b994e..1a36333c9aa 100644 --- a/docs/api/qiskit/qiskit.qobj.QasmQobj.mdx +++ b/docs/api/qiskit/qiskit.qobj.QasmQobj.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QasmQobj # QasmQobj - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") An OpenQASM 2 Qobj. @@ -28,7 +28,7 @@ python_api_name: qiskit.qobj.QasmQobj ### from\_dict - + Create a new QASMQobj object from a dictionary. **Parameters** @@ -46,7 +46,7 @@ python_api_name: qiskit.qobj.QasmQobj ### 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: diff --git a/docs/api/qiskit/qiskit.qobj.QasmQobjConfig.mdx b/docs/api/qiskit/qiskit.qobj.QasmQobjConfig.mdx index c15f0a30f82..3c924b5937b 100644 --- a/docs/api/qiskit/qiskit.qobj.QasmQobjConfig.mdx +++ b/docs/api/qiskit/qiskit.qobj.QasmQobjConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QasmQobjConfig # QasmQobjConfig - + Bases: [`SimpleNamespace`](https://docs.python.org/3/library/types.html#types.SimpleNamespace "(in Python v3.12)") A configuration for an OpenQASM 2 Qobj. @@ -36,7 +36,7 @@ python_api_name: qiskit.qobj.QasmQobjConfig ### from\_dict - + Create a new QasmQobjConfig object from a dictionary. **Parameters** @@ -54,7 +54,7 @@ python_api_name: qiskit.qobj.QasmQobjConfig ### to\_dict - + Return a dictionary format representation of the OpenQASM 2 Qobj config. **Returns** diff --git a/docs/api/qiskit/qiskit.qobj.QasmQobjExperiment.mdx b/docs/api/qiskit/qiskit.qobj.QasmQobjExperiment.mdx index bb84c4f6d32..a658dcd9605 100644 --- a/docs/api/qiskit/qiskit.qobj.QasmQobjExperiment.mdx +++ b/docs/api/qiskit/qiskit.qobj.QasmQobjExperiment.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QasmQobjExperiment # QasmQobjExperiment - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") An OpenQASM 2 Qobj Experiment. @@ -27,7 +27,7 @@ python_api_name: qiskit.qobj.QasmQobjExperiment ### from\_dict - + Create a new QasmQobjExperiment object from a dictionary. **Parameters** @@ -45,7 +45,7 @@ python_api_name: qiskit.qobj.QasmQobjExperiment ### to\_dict - + Return a dictionary format representation of the Experiment. **Returns** diff --git a/docs/api/qiskit/qiskit.qobj.QasmQobjExperimentConfig.mdx b/docs/api/qiskit/qiskit.qobj.QasmQobjExperimentConfig.mdx index d3ef90eb5c0..616ab336a34 100644 --- a/docs/api/qiskit/qiskit.qobj.QasmQobjExperimentConfig.mdx +++ b/docs/api/qiskit/qiskit.qobj.QasmQobjExperimentConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QasmQobjExperimentConfig # QasmQobjExperimentConfig - + Bases: `QobjDictField` Configuration for a single OpenQASM 2 experiment in the qobj. @@ -24,7 +24,7 @@ python_api_name: qiskit.qobj.QasmQobjExperimentConfig ### from\_dict - + Create a new QobjHeader object from a dictionary. **Parameters** @@ -42,7 +42,7 @@ python_api_name: qiskit.qobj.QasmQobjExperimentConfig ### to\_dict - + Return a dictionary format representation of the OpenQASM 2 Qobj. **Returns** diff --git a/docs/api/qiskit/qiskit.qobj.QasmQobjInstruction.mdx b/docs/api/qiskit/qiskit.qobj.QasmQobjInstruction.mdx index 2d8359bdbb1..719a5a25bbf 100644 --- a/docs/api/qiskit/qiskit.qobj.QasmQobjInstruction.mdx +++ b/docs/api/qiskit/qiskit.qobj.QasmQobjInstruction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QasmQobjInstruction # QasmQobjInstruction - + 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. @@ -34,7 +34,7 @@ python_api_name: qiskit.qobj.QasmQobjInstruction ### from\_dict - + Create a new QasmQobjInstruction object from a dictionary. **Parameters** @@ -52,7 +52,7 @@ python_api_name: qiskit.qobj.QasmQobjInstruction ### to\_dict - + Return a dictionary format representation of the Instruction. **Returns** diff --git a/docs/api/qiskit/qiskit.qobj.QobjExperimentHeader.mdx b/docs/api/qiskit/qiskit.qobj.QobjExperimentHeader.mdx index 87644c92818..34ecd298cd0 100644 --- a/docs/api/qiskit/qiskit.qobj.QobjExperimentHeader.mdx +++ b/docs/api/qiskit/qiskit.qobj.QobjExperimentHeader.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QobjExperimentHeader # QobjExperimentHeader - + Bases: [`QobjHeader`](qiskit.qobj.QobjHeader "qiskit.qobj.common.QobjHeader") A class representing a header dictionary for a Qobj Experiment. @@ -23,7 +23,7 @@ python_api_name: qiskit.qobj.QobjExperimentHeader ### from\_dict - + Create a new QobjHeader object from a dictionary. **Parameters** @@ -41,7 +41,7 @@ python_api_name: qiskit.qobj.QobjExperimentHeader ### to\_dict - + Return a dictionary format representation of the OpenQASM 2 Qobj. **Returns** diff --git a/docs/api/qiskit/qiskit.qobj.QobjHeader.mdx b/docs/api/qiskit/qiskit.qobj.QobjHeader.mdx index 4ff4d79cd0e..7e50b6a3349 100644 --- a/docs/api/qiskit/qiskit.qobj.QobjHeader.mdx +++ b/docs/api/qiskit/qiskit.qobj.QobjHeader.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QobjHeader # QobjHeader - + Bases: `QobjDictField` A class used to represent a dictionary header in Qobj objects. @@ -23,7 +23,7 @@ python_api_name: qiskit.qobj.QobjHeader ### from\_dict - + Create a new QobjHeader object from a dictionary. **Parameters** @@ -41,7 +41,7 @@ python_api_name: qiskit.qobj.QobjHeader ### to\_dict - + Return a dictionary format representation of the OpenQASM 2 Qobj. **Returns** diff --git a/docs/api/qiskit/qiskit.qobj.QobjMeasurementOption.mdx b/docs/api/qiskit/qiskit.qobj.QobjMeasurementOption.mdx index 99f81b39402..7b0042a8e79 100644 --- a/docs/api/qiskit/qiskit.qobj.QobjMeasurementOption.mdx +++ b/docs/api/qiskit/qiskit.qobj.QobjMeasurementOption.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.qobj.QobjMeasurementOption # QobjMeasurementOption - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") An individual measurement option. @@ -24,7 +24,7 @@ python_api_name: qiskit.qobj.QobjMeasurementOption ### from\_dict - + Create a new QobjMeasurementOption object from a dictionary. **Parameters** @@ -42,7 +42,7 @@ python_api_name: qiskit.qobj.QobjMeasurementOption ### to\_dict - + Return a dict format representation of the QobjMeasurementOption. **Returns** diff --git a/docs/api/qiskit/qiskit.quantum_info.CNOTDihedral.mdx b/docs/api/qiskit/qiskit.quantum_info.CNOTDihedral.mdx index 2d402d10e39..0dba9e8839d 100644 --- a/docs/api/qiskit/qiskit.quantum_info.CNOTDihedral.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.CNOTDihedral.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.CNOTDihedral # CNOTDihedral - + Bases: `BaseOperator`, `AdjointMixin` An N-qubit operator from the CNOT-Dihedral group. @@ -106,13 +106,13 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### adjoint - + Return the adjoint of the Operator. ### compose - + Return the operator composition with another CNOTDihedral. **Parameters** @@ -142,19 +142,19 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### conjugate - + Return the conjugate of the CNOTDihedral. ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -177,7 +177,7 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### expand - + Return the reverse-order tensor product with another CNOTDihedral. **Parameters** @@ -197,19 +197,19 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### input\_dims - + Return tuple of input dimension for specified subsystems. ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the compose of a operator with itself n times. **Parameters** @@ -231,7 +231,7 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -255,7 +255,7 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### tensor - + Return the tensor product with another CNOTDihedral. **Parameters** @@ -279,7 +279,7 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### to\_circuit - + Return a QuantumCircuit implementing the CNOT-Dihedral element. **Returns** @@ -298,19 +298,19 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### to\_instruction - + Return a Gate instruction implementing the CNOTDihedral object. ### to\_matrix - + Convert operator to Numpy matrix. ### to\_operator - + Convert to an Operator object. **Return type** @@ -320,7 +320,7 @@ python_api_name: qiskit.quantum_info.CNOTDihedral ### transpose - + Return the transpose of the CNOTDihedral. diff --git a/docs/api/qiskit/qiskit.quantum_info.Chi.mdx b/docs/api/qiskit/qiskit.quantum_info.Chi.mdx index e5ec426af15..40ca803efd9 100644 --- a/docs/api/qiskit/qiskit.quantum_info.Chi.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.Chi.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Chi # Chi - + Bases: `QuantumChannel` Pauli basis Chi-matrix representation of a quantum channel. @@ -87,7 +87,7 @@ $$ ### adjoint - + Return the adjoint quantum channel. @@ -97,7 +97,7 @@ $$ ### compose - + Return the operator composition with another Chi. **Parameters** @@ -127,7 +127,7 @@ $$ ### conjugate - + Return the conjugate quantum channel. @@ -137,13 +137,13 @@ $$ ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -166,7 +166,7 @@ $$ ### expand - + Return the reverse-order tensor product with another Chi. **Parameters** @@ -186,13 +186,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_cp - + Test if Choi-matrix is completely-positive (CP) **Return type** @@ -202,7 +202,7 @@ $$ ### is\_cptp - + Return True if completely-positive trace-preserving (CPTP). **Return type** @@ -212,7 +212,7 @@ $$ ### is\_tp - + Test if a channel is trace-preserving (TP) **Return type** @@ -222,7 +222,7 @@ $$ ### is\_unitary - + Return True if QuantumChannel is a unitary channel. **Return type** @@ -232,13 +232,13 @@ $$ ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the power of the quantum channel. **Parameters** @@ -264,7 +264,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -288,7 +288,7 @@ $$ ### tensor - + Return the tensor product with another Chi. **Parameters** @@ -312,7 +312,7 @@ $$ ### 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. @@ -332,7 +332,7 @@ $$ ### to\_operator - + Try to convert channel to a unitary representation Operator. **Return type** @@ -342,7 +342,7 @@ $$ ### transpose - + Return the transpose quantum channel. diff --git a/docs/api/qiskit/qiskit.quantum_info.Choi.mdx b/docs/api/qiskit/qiskit.quantum_info.Choi.mdx index b2b4bcaa09d..fab577f2737 100644 --- a/docs/api/qiskit/qiskit.quantum_info.Choi.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.Choi.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Choi # Choi - + Bases: `QuantumChannel` Choi-matrix representation of a Quantum Channel. @@ -95,7 +95,7 @@ $$ ### adjoint - + Return the adjoint quantum channel. @@ -109,7 +109,7 @@ $$ ### compose - + Return the operator composition with another Choi. **Parameters** @@ -139,7 +139,7 @@ $$ ### conjugate - + Return the conjugate quantum channel. @@ -149,13 +149,13 @@ $$ ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -178,7 +178,7 @@ $$ ### expand - + Return the reverse-order tensor product with another Choi. **Parameters** @@ -198,13 +198,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_cp - + Test if Choi-matrix is completely-positive (CP) **Return type** @@ -214,7 +214,7 @@ $$ ### is\_cptp - + Return True if completely-positive trace-preserving (CPTP). **Return type** @@ -224,7 +224,7 @@ $$ ### is\_tp - + Test if a channel is trace-preserving (TP) **Return type** @@ -234,7 +234,7 @@ $$ ### is\_unitary - + Return True if QuantumChannel is a unitary channel. **Return type** @@ -244,13 +244,13 @@ $$ ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the power of the quantum channel. **Parameters** @@ -276,7 +276,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -300,7 +300,7 @@ $$ ### tensor - + Return the tensor product with another Choi. **Parameters** @@ -324,7 +324,7 @@ $$ ### 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. @@ -344,7 +344,7 @@ $$ ### to\_operator - + Try to convert channel to a unitary representation Operator. **Return type** @@ -354,7 +354,7 @@ $$ ### transpose - + Return the transpose quantum channel. diff --git a/docs/api/qiskit/qiskit.quantum_info.Clifford.mdx b/docs/api/qiskit/qiskit.quantum_info.Clifford.mdx index 3f8e129564c..d02897a095d 100644 --- a/docs/api/qiskit/qiskit.quantum_info.Clifford.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.Clifford.mdx @@ -8,11 +8,19 @@ python_api_name: qiskit.quantum_info.Clifford # Clifford - + Bases: `BaseOperator`, `AdjointMixin`, [`Operation`](qiskit.circuit.Operation "qiskit.circuit.operation.Operation") An N-qubit unitary operator from the Clifford group. + An N-qubit Clifford operator takes Paulis to Paulis via conjugation (up to a global phase). More precisely, the Clifford group $\mathcal{C}_N$ is defined as + + > $$ + > \mathcal{C}_N = \{ U \in U(2^N) | U \mathcal{P}_N U^{\dagger} = \mathcal{P}_N \} / U(1) + > $$ + > + > where $\mathcal{P}_N$ is the Pauli group on $N$ qubits that is generated by single-qubit Pauli operators, and $U$ is a unitary operator in the unitary group $U(2^N)$ representing operations on $N$ qubits. $\mathcal{C}_N$ is the quotient group by the subgroup of scalar unitary matrices $U(1)$. + **Representation** An *N*-qubit Clifford operator is stored as a length *2N × (2N+1)* boolean tableau using the convention from reference \[1]. @@ -52,7 +60,7 @@ python_api_name: qiskit.quantum_info.Clifford **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. + 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"), [`DCXGate`](qiskit.circuit.library.DCXGate "qiskit.circuit.library.DCXGate"), [`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. @@ -174,13 +182,13 @@ python_api_name: qiskit.quantum_info.Clifford ### adjoint - + Return the adjoint of the Operator. ### compose - + Return the operator composition with another Clifford. **Parameters** @@ -210,19 +218,19 @@ python_api_name: qiskit.quantum_info.Clifford ### conjugate - + Return the conjugate of the Clifford. ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -245,7 +253,7 @@ python_api_name: qiskit.quantum_info.Clifford ### expand - + Return the reverse-order tensor product with another Clifford. **Parameters** @@ -265,7 +273,7 @@ python_api_name: qiskit.quantum_info.Clifford ### from\_circuit - + Initialize from a QuantumCircuit or Instruction. **Parameters** @@ -287,13 +295,13 @@ python_api_name: qiskit.quantum_info.Clifford ### from\_dict - + Load a Clifford from a dictionary ### from\_label - + Return a tensor product of single-qubit Clifford gates. **Parameters** @@ -341,7 +349,7 @@ python_api_name: qiskit.quantum_info.Clifford ### from\_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}]]. @@ -361,7 +369,7 @@ python_api_name: qiskit.quantum_info.Clifford ### from\_matrix - + Create a Clifford from a unitary matrix. Note that this function takes exponentially long time w\.r.t. the number of qubits. @@ -385,7 +393,7 @@ python_api_name: qiskit.quantum_info.Clifford ### from\_operator - + Create a Clifford from a operator. Note that this function takes exponentially long time w\.r.t. the number of qubits. @@ -409,7 +417,7 @@ python_api_name: qiskit.quantum_info.Clifford ### from\_permutation - + Create a Clifford from a PermutationGate. **Parameters** @@ -427,25 +435,25 @@ python_api_name: qiskit.quantum_info.Clifford ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_unitary - + Return True if the Clifford table is valid. ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the compose of a operator with itself n times. **Parameters** @@ -467,7 +475,7 @@ python_api_name: qiskit.quantum_info.Clifford ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -491,7 +499,7 @@ python_api_name: qiskit.quantum_info.Clifford ### tensor - + Return the tensor product with another Clifford. **Parameters** @@ -515,7 +523,7 @@ python_api_name: qiskit.quantum_info.Clifford ### 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]. @@ -536,19 +544,19 @@ python_api_name: qiskit.quantum_info.Clifford ### to\_dict - + Return dictionary representation of Clifford object. ### to\_instruction - + Return a Gate instruction implementing the Clifford. ### to\_labels - + 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. @@ -584,13 +592,13 @@ python_api_name: qiskit.quantum_info.Clifford ### to\_matrix - + Convert operator to Numpy matrix. ### to\_operator - + Convert to an Operator object. **Return type** @@ -600,7 +608,7 @@ python_api_name: qiskit.quantum_info.Clifford ### transpose - + Return the transpose of the Clifford. diff --git a/docs/api/qiskit/qiskit.quantum_info.DensityMatrix.mdx b/docs/api/qiskit/qiskit.quantum_info.DensityMatrix.mdx index c764ed75563..2f769b670d8 100644 --- a/docs/api/qiskit/qiskit.quantum_info.DensityMatrix.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.DensityMatrix.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix # DensityMatrix - + Bases: `QuantumState`, `TolerancesMixin` DensityMatrix class @@ -69,25 +69,25 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### conjugate - + Return the conjugate of the density matrix. ### copy - + Make a copy of current operator. ### dims - + Return tuple of input dimension for specified subsystems. ### draw - + Return a visualization of the Statevector. **repr**: ASCII TextMatrix of the state’s `__repr__`. @@ -120,7 +120,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### evolve - + Evolve a quantum state by an operator. **Parameters** @@ -143,7 +143,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### expand - + Return the tensor product state other ⊗ self. **Parameters** @@ -165,7 +165,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### expectation\_value - + Compute the expectation value of an operator. **Parameters** @@ -184,7 +184,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### from\_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. @@ -208,7 +208,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### from\_int - + Return a computational basis state density matrix. **Parameters** @@ -234,7 +234,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### from\_label - + Return a tensor product of Pauli X,Y,Z eigenstates. | Label | Statevector | @@ -265,13 +265,13 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### is\_valid - + Return True if trace 1 and positive semidefinite. ### measure - + 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. @@ -293,7 +293,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### partial\_transpose - + Return partially transposed density matrix. **Parameters** @@ -311,7 +311,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### probabilities - + Return the subsystem measurement probability vector. Measurement probabilities are with respect to measurement in the computation (diagonal) basis. @@ -382,7 +382,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### probabilities\_dict - + Return the subsystem measurement probability dictionary. Measurement probabilities are with respect to measurement in the computation (diagonal) basis. @@ -405,13 +405,13 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### purity - + Return the purity of the quantum state. ### reset - + Reset state or subsystems to the 0-state. **Parameters** @@ -433,7 +433,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### 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}$. @@ -449,7 +449,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### sample\_counts - + Sample a dict of qubit measurement outcomes in the computational basis. **Parameters** @@ -474,7 +474,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### sample\_memory - + Sample a list of qubit measurement outcomes in the computational basis. **Parameters** @@ -499,13 +499,13 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### seed - + Set the seed for the quantum state RNG. ### tensor - + Return the tensor product state self ⊗ other. **Parameters** @@ -527,7 +527,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### to\_dict - + 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. @@ -603,7 +603,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### to\_operator - + Convert to Operator **Return type** @@ -613,7 +613,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### to\_statevector - + Return a statevector from a pure density matrix. **Parameters** @@ -638,7 +638,7 @@ python_api_name: qiskit.quantum_info.DensityMatrix ### trace - + Return the trace of the density matrix. diff --git a/docs/api/qiskit/qiskit.quantum_info.Kraus.mdx b/docs/api/qiskit/qiskit.quantum_info.Kraus.mdx index c9622d711c4..66fbe034291 100644 --- a/docs/api/qiskit/qiskit.quantum_info.Kraus.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.Kraus.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Kraus # Kraus - + Bases: `QuantumChannel` Kraus representation of a quantum channel. @@ -91,7 +91,7 @@ $$ ### adjoint - + Return the adjoint quantum channel. @@ -101,7 +101,7 @@ $$ ### compose - + Return the operator composition with another Kraus. **Parameters** @@ -131,7 +131,7 @@ $$ ### conjugate - + Return the conjugate quantum channel. @@ -141,13 +141,13 @@ $$ ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -170,7 +170,7 @@ $$ ### expand - + Return the reverse-order tensor product with another Kraus. **Parameters** @@ -190,13 +190,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_cp - + Test if Choi-matrix is completely-positive (CP) **Return type** @@ -206,13 +206,13 @@ $$ ### is\_cptp - + Return True if completely-positive trace-preserving. ### is\_tp - + Test if a channel is trace-preserving (TP) **Return type** @@ -222,7 +222,7 @@ $$ ### is\_unitary - + Return True if QuantumChannel is a unitary channel. **Return type** @@ -232,13 +232,13 @@ $$ ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the power of the quantum channel. **Parameters** @@ -264,7 +264,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -288,7 +288,7 @@ $$ ### tensor - + Return the tensor product with another Kraus. **Parameters** @@ -312,7 +312,7 @@ $$ ### 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. @@ -332,7 +332,7 @@ $$ ### to\_operator - + Try to convert channel to a unitary representation Operator. **Return type** @@ -342,7 +342,7 @@ $$ ### transpose - + Return the transpose quantum channel. diff --git a/docs/api/qiskit/qiskit.quantum_info.Operator.mdx b/docs/api/qiskit/qiskit.quantum_info.Operator.mdx index 798393e1c6d..aed6aa86f43 100644 --- a/docs/api/qiskit/qiskit.quantum_info.Operator.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.Operator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Operator # Operator - + Bases: `LinearOp` Matrix operator class @@ -39,7 +39,7 @@ $$ **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. + 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. Note that two operators initialized via this method are only considered equivalent if they match up to their canonical qubit order (or: permutation). See [`Operator.from_circuit()`](#qiskit.quantum_info.Operator.from_circuit "qiskit.quantum_info.Operator.from_circuit") to specify a different qubit permutation. ## Attributes @@ -85,7 +85,7 @@ $$ ### adjoint - + Return the adjoint of the Operator. **Return type** @@ -95,7 +95,7 @@ $$ ### apply\_permutation - + Modifies operator’s data by composing it with a permutation. **Parameters** @@ -118,7 +118,7 @@ $$ ### compose - + Return the operator composition with another Operator. **Parameters** @@ -148,19 +148,19 @@ $$ ### conjugate - + Return the conjugate of the Operator. ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -183,7 +183,7 @@ $$ ### draw - + Return a visualization of the Operator. **repr**: String of the state’s `__repr__`. @@ -214,7 +214,7 @@ $$ ### equiv - + Return True if operators are equivalent up to global phase. **Parameters** @@ -234,7 +234,7 @@ $$ ### expand - + Return the reverse-order tensor product with another Operator. **Parameters** @@ -254,7 +254,7 @@ $$ ### from\_circuit - + 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. @@ -279,7 +279,7 @@ $$ ### from\_label - + Return a tensor product of single-qubit operators. **Parameters** @@ -305,25 +305,25 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_unitary - + Return True if operator is a unitary matrix. ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the matrix power of the operator. **Parameters** @@ -345,7 +345,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -369,7 +369,7 @@ $$ ### 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}$. @@ -385,7 +385,7 @@ $$ ### tensor - + Return the tensor product with another Operator. **Parameters** @@ -409,19 +409,19 @@ $$ ### to\_instruction - + Convert to a UnitaryGate instruction. ### to\_matrix - + Convert operator to NumPy matrix. ### to\_operator - + Convert operator to matrix operator class **Return type** @@ -431,7 +431,7 @@ $$ ### transpose - + Return the transpose of the Operator. diff --git a/docs/api/qiskit/qiskit.quantum_info.PTM.mdx b/docs/api/qiskit/qiskit.quantum_info.PTM.mdx index ceaf46a6031..b8b14aa9a2f 100644 --- a/docs/api/qiskit/qiskit.quantum_info.PTM.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.PTM.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.PTM # PTM - + Bases: `QuantumChannel` Pauli Transfer Matrix (PTM) representation of a Quantum Channel. @@ -95,7 +95,7 @@ $$ ### adjoint - + Return the adjoint quantum channel. @@ -105,7 +105,7 @@ $$ ### compose - + Return the operator composition with another PTM. **Parameters** @@ -135,7 +135,7 @@ $$ ### conjugate - + Return the conjugate quantum channel. @@ -145,13 +145,13 @@ $$ ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -174,7 +174,7 @@ $$ ### expand - + Return the reverse-order tensor product with another PTM. **Parameters** @@ -194,13 +194,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_cp - + Test if Choi-matrix is completely-positive (CP) **Return type** @@ -210,7 +210,7 @@ $$ ### is\_cptp - + Return True if completely-positive trace-preserving (CPTP). **Return type** @@ -220,7 +220,7 @@ $$ ### is\_tp - + Test if a channel is trace-preserving (TP) **Return type** @@ -230,7 +230,7 @@ $$ ### is\_unitary - + Return True if QuantumChannel is a unitary channel. **Return type** @@ -240,13 +240,13 @@ $$ ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the power of the quantum channel. **Parameters** @@ -272,7 +272,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -296,7 +296,7 @@ $$ ### tensor - + Return the tensor product with another PTM. **Parameters** @@ -320,7 +320,7 @@ $$ ### 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. @@ -340,7 +340,7 @@ $$ ### to\_operator - + Try to convert channel to a unitary representation Operator. **Return type** @@ -350,7 +350,7 @@ $$ ### transpose - + Return the transpose quantum channel. diff --git a/docs/api/qiskit/qiskit.quantum_info.Pauli.mdx b/docs/api/qiskit/qiskit.quantum_info.Pauli.mdx index 0633ddea9d8..3c9db2da625 100644 --- a/docs/api/qiskit/qiskit.quantum_info.Pauli.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.Pauli.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Pauli # Pauli - + Bases: `BasePauli` N-qubit Pauli operator. @@ -88,13 +88,13 @@ $$ For example ```python - p = Pauli('-iXYZ') + 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])) + print('P[::-1] =', repr(P[::-1])) ``` Initialize the Pauli. @@ -169,13 +169,13 @@ $$ ### adjoint - + Return the adjoint of the Operator. ### anticommutes - + Return True if other Pauli anticommutes with self. **Parameters** @@ -192,9 +192,28 @@ $$ [bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + ### apply\_layout + + + Apply a transpiler layout to this [`Pauli`](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") + + **Parameters** + + * **layout** ([*TranspileLayout*](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") *|*[*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*) – Either a [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout"), a list of integers or None. If both layout and num\_qubits are none, a copy of the operator is returned. + * **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. If layout is None, the operator will be expanded to the given number of qubits. + + **Returns** + + A new [`Pauli`](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") with the provided layout applied + + **Return type** + + [Pauli](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") + + ### commutes - + Return True if the Pauli commutes with other. **Parameters** @@ -213,7 +232,7 @@ $$ ### compose - + Return the operator composition with another Pauli. **Parameters** @@ -244,19 +263,19 @@ $$ ### conjugate - + Return the conjugate of each Pauli in the list. ### copy - + Make a deep copy of current operator. ### delete - + Return a Pauli with qubits deleted. **Parameters** @@ -278,7 +297,7 @@ $$ ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -298,7 +317,7 @@ $$ ### equiv - + Return True if Pauli’s are equivalent up to group phase. **Parameters** @@ -316,7 +335,7 @@ $$ ### evolve - + 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. @@ -347,7 +366,7 @@ $$ ### expand - + Return the reverse-order tensor product with another Pauli. **Parameters** @@ -367,13 +386,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### insert - + Insert a Pauli at specific qubit value. **Parameters** @@ -396,19 +415,19 @@ $$ ### inverse - + Return the inverse of the Pauli. ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the compose of a operator with itself n times. **Parameters** @@ -430,7 +449,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -454,7 +473,7 @@ $$ ### set\_truncation - + Set the max number of Pauli characters to display before truncation/ **Parameters** @@ -468,7 +487,7 @@ $$ ### tensor - + Return the tensor product with another Pauli. **Parameters** @@ -492,13 +511,13 @@ $$ ### to\_instruction - + Convert to Pauli circuit instruction. ### to\_label - + Convert a Pauli to a string label. @@ -516,7 +535,7 @@ $$ ### to\_matrix - + Convert to a Numpy array or sparse CSR matrix. **Parameters** @@ -534,7 +553,7 @@ $$ ### transpose - + Return the transpose of each Pauli in the list. diff --git a/docs/api/qiskit/qiskit.quantum_info.PauliList.mdx b/docs/api/qiskit/qiskit.quantum_info.PauliList.mdx index ee0458aea6f..a6e6abdf13d 100644 --- a/docs/api/qiskit/qiskit.quantum_info.PauliList.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.PauliList.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.PauliList # PauliList - + Bases: `BasePauli`, `LinearMixin`, `GroupMixin` List of N-qubit Pauli operators. @@ -161,13 +161,13 @@ python_api_name: qiskit.quantum_info.PauliList ### adjoint - + Return the adjoint of each Pauli in the list. ### anticommutes - + Return `True` if other Pauli that anticommutes with other. **Parameters** @@ -186,7 +186,7 @@ python_api_name: qiskit.quantum_info.PauliList ### anticommutes\_with\_all - + 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. @@ -206,7 +206,7 @@ python_api_name: qiskit.quantum_info.PauliList ### argsort - + 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. @@ -227,7 +227,7 @@ python_api_name: qiskit.quantum_info.PauliList ### commutes - + Return True for each Pauli that commutes with other. **Parameters** @@ -246,7 +246,7 @@ python_api_name: qiskit.quantum_info.PauliList ### commutes\_with\_all - + 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. @@ -266,7 +266,7 @@ python_api_name: qiskit.quantum_info.PauliList ### compose - + Return the composition self∘other for each Pauli in the list. **Parameters** @@ -291,19 +291,19 @@ python_api_name: qiskit.quantum_info.PauliList ### conjugate - + Return the conjugate of each Pauli in the list. ### copy - + Make a deep copy of current operator. ### delete - + 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. @@ -328,7 +328,7 @@ python_api_name: qiskit.quantum_info.PauliList ### dot - + Return the composition other∘self for each Pauli in the list. **Parameters** @@ -352,7 +352,7 @@ python_api_name: qiskit.quantum_info.PauliList ### equiv - + Entrywise comparison of Pauli equivalence up to global phase. **Parameters** @@ -372,7 +372,7 @@ python_api_name: qiskit.quantum_info.PauliList ### evolve - + 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. @@ -402,7 +402,7 @@ python_api_name: qiskit.quantum_info.PauliList ### expand - + Return the expand product of each Pauli in the list. **Parameters** @@ -424,7 +424,7 @@ python_api_name: qiskit.quantum_info.PauliList ### from\_symplectic - + Construct a PauliList from a symplectic data. **Parameters** @@ -444,7 +444,7 @@ python_api_name: qiskit.quantum_info.PauliList ### group\_commuting - + Partition a PauliList into sets of commuting Pauli strings. **Parameters** @@ -473,7 +473,7 @@ python_api_name: qiskit.quantum_info.PauliList ### group\_qubit\_wise\_commuting - + Partition a PauliList into sets of mutually qubit-wise commuting Pauli strings. **Returns** @@ -487,13 +487,13 @@ python_api_name: qiskit.quantum_info.PauliList ### input\_dims - + Return tuple of input dimension for specified subsystems. ### insert - + 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. @@ -519,13 +519,13 @@ python_api_name: qiskit.quantum_info.PauliList ### inverse - + Return the inverse of each Pauli in the list. ### 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. @@ -541,7 +541,7 @@ python_api_name: qiskit.quantum_info.PauliList ### matrix\_iter - + 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. @@ -559,15 +559,37 @@ python_api_name: qiskit.quantum_info.PauliList MatrixIterator + ### noncommutation\_graph + + + Create the non-commutation graph of this PauliList. + + This transforms the measurement operator grouping problem into graph coloring problem. The constructed graph contains one node for each Pauli. The nodes will be connecting for any two Pauli terms that do \_not\_ commute. + + **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. + + **Returns** + + **the non-commutation graph with nodes for each Pauli and edges** + + indicating a non-commutation relation. Each node will hold the index of the Pauli term it corresponds to in its data. The edges of the graph hold no data. + + **Return type** + + [rustworkx.PyGraph](https://www.rustworkx.org/apiref/rustworkx.PyGraph.html#rustworkx.PyGraph "(in rustworkx v0.14)") + + ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the compose of a operator with itself n times. **Parameters** @@ -589,7 +611,7 @@ python_api_name: qiskit.quantum_info.PauliList ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -613,7 +635,7 @@ python_api_name: qiskit.quantum_info.PauliList ### sort - + 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. @@ -674,7 +696,7 @@ python_api_name: qiskit.quantum_info.PauliList ### tensor - + Return the tensor product with each Pauli in the list. **Parameters** @@ -696,7 +718,7 @@ python_api_name: qiskit.quantum_info.PauliList ### to\_labels - + 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. @@ -723,7 +745,7 @@ python_api_name: qiskit.quantum_info.PauliList ### to\_matrix - + 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. @@ -751,13 +773,13 @@ python_api_name: qiskit.quantum_info.PauliList ### transpose - + Return the transpose of each Pauli in the list. ### unique - + Return unique Paulis from the table. **Example** diff --git a/docs/api/qiskit/qiskit.quantum_info.Quaternion.mdx b/docs/api/qiskit/qiskit.quantum_info.Quaternion.mdx index a29535d7e7e..baf0c2ae491 100644 --- a/docs/api/qiskit/qiskit.quantum_info.Quaternion.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.Quaternion.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Quaternion # Quaternion - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") A class representing a Quaternion. @@ -17,7 +17,7 @@ python_api_name: qiskit.quantum_info.Quaternion ### from\_axis\_rotation - + Return quaternion for rotation about given axis. **Parameters** @@ -40,7 +40,7 @@ python_api_name: qiskit.quantum_info.Quaternion ### from\_euler - + Generate a quaternion from a set of Euler angles. **Parameters** @@ -59,13 +59,13 @@ python_api_name: qiskit.quantum_info.Quaternion ### norm - + Norm of quaternion. ### normalize - + Normalizes a Quaternion to unit length so that it represents a valid rotation. **Parameters** @@ -83,7 +83,7 @@ python_api_name: qiskit.quantum_info.Quaternion ### to\_matrix - + Converts a unit-length quaternion to a rotation matrix. **Returns** @@ -97,7 +97,7 @@ python_api_name: qiskit.quantum_info.Quaternion ### to\_zyz - + Converts a unit-length quaternion to a sequence of ZYZ Euler angles. **Returns** diff --git a/docs/api/qiskit/qiskit.quantum_info.ScalarOp.mdx b/docs/api/qiskit/qiskit.quantum_info.ScalarOp.mdx index 40c52df5738..0b245c45094 100644 --- a/docs/api/qiskit/qiskit.quantum_info.ScalarOp.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.ScalarOp.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.ScalarOp # ScalarOp - + Bases: `LinearOp` Scalar identity operator class. @@ -64,7 +64,7 @@ python_api_name: qiskit.quantum_info.ScalarOp ### adjoint - + Return the adjoint of the Operator. **Return type** @@ -74,7 +74,7 @@ python_api_name: qiskit.quantum_info.ScalarOp ### compose - + Return the operator composition with another ScalarOp. **Parameters** @@ -104,19 +104,19 @@ python_api_name: qiskit.quantum_info.ScalarOp ### conjugate - + Return the conjugate of the ScalarOp. ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -139,7 +139,7 @@ python_api_name: qiskit.quantum_info.ScalarOp ### expand - + Return the reverse-order tensor product with another ScalarOp. **Parameters** @@ -159,25 +159,25 @@ python_api_name: qiskit.quantum_info.ScalarOp ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_unitary - + Return True if operator is a unitary matrix. ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the power of the ScalarOp. **Parameters** @@ -195,7 +195,7 @@ python_api_name: qiskit.quantum_info.ScalarOp ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -219,7 +219,7 @@ python_api_name: qiskit.quantum_info.ScalarOp ### tensor - + Return the tensor product with another ScalarOp. **Parameters** @@ -243,13 +243,13 @@ python_api_name: qiskit.quantum_info.ScalarOp ### to\_matrix - + Convert to a Numpy matrix. ### to\_operator - + Convert to an Operator object. **Return type** @@ -259,7 +259,7 @@ python_api_name: qiskit.quantum_info.ScalarOp ### transpose - + Return the transpose of the ScalarOp. diff --git a/docs/api/qiskit/qiskit.quantum_info.SparsePauliOp.mdx b/docs/api/qiskit/qiskit.quantum_info.SparsePauliOp.mdx index cc1f667ab98..d6414e44ff0 100644 --- a/docs/api/qiskit/qiskit.quantum_info.SparsePauliOp.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.SparsePauliOp.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp # SparsePauliOp - + Bases: `LinearOp` Sparse N-qubit operator in a Pauli basis representation. @@ -127,13 +127,13 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### adjoint - + Return the adjoint of the Operator. ### apply\_layout - + Apply a transpiler layout to this [`SparsePauliOp`](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") **Parameters** @@ -152,7 +152,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### argsort - + 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. @@ -220,7 +220,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### assign\_parameters - + Bind the free `Parameter`s in the coefficients to provided values. **Parameters** @@ -239,7 +239,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### chop - + 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`. @@ -261,7 +261,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### compose - + Return the operator composition with another SparsePauliOp. **Parameters** @@ -291,19 +291,19 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### conjugate - + Return the conjugate of the SparsePauliOp. ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -326,7 +326,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### equiv - + Check if two SparsePauliOp operators are equivalent. **Parameters** @@ -345,7 +345,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### expand - + Return the reverse-order tensor product with another SparsePauliOp. **Parameters** @@ -365,7 +365,7 @@ python_api_name: qiskit.quantum_info.SparsePauliOp ### from\_list - + Construct from a list of Pauli strings and coefficients. For example, the 5-qubit Hamiltonian @@ -403,7 +403,7 @@ $$ ### from\_operator - + Construct from an Operator objector. Note that the cost of this construction is exponential in general because the number of possible Pauli terms in the decomposition is exponential in the number of qubits. @@ -431,7 +431,7 @@ $$ ### from\_sparse\_list - + 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. @@ -476,7 +476,7 @@ $$ ### group\_commuting - + Partition a SparsePauliOp into sets of commuting Pauli strings. **Parameters** @@ -509,13 +509,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_unitary - + Return True if operator is a unitary matrix. **Parameters** @@ -534,7 +534,7 @@ $$ ### 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. @@ -550,7 +550,7 @@ $$ ### matrix\_iter - + 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. @@ -568,15 +568,37 @@ $$ MatrixIterator + ### noncommutation\_graph + + + Create the non-commutation graph of this SparsePauliOp. + + This transforms the measurement operator grouping problem into graph coloring problem. The constructed graph contains one node for each Pauli. The nodes will be connecting for any two Pauli terms that do \_not\_ commute. + + **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. + + **Returns** + + **the non-commutation graph with nodes for each Pauli and edges** + + indicating a non-commutation relation. Each node will hold the index of the Pauli term it corresponds to in its data. The edges of the graph hold no data. + + **Return type** + + [rustworkx.PyGraph](https://www.rustworkx.org/apiref/rustworkx.PyGraph.html#rustworkx.PyGraph "(in rustworkx v0.14)") + + ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the compose of a operator with itself n times. **Parameters** @@ -598,7 +620,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -622,7 +644,7 @@ $$ ### simplify - + Simplify PauliList by combining duplicates and removing zeros. **Parameters** @@ -641,7 +663,7 @@ $$ ### sort - + 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. @@ -712,7 +734,7 @@ $$ ### sum - + Sum of SparsePauliOps. This is a specialized version of the builtin `sum` function for SparsePauliOp with smaller overhead. @@ -738,7 +760,7 @@ $$ ### tensor - + Return the tensor product with another SparsePauliOp. **Parameters** @@ -762,7 +784,7 @@ $$ ### to\_list - + 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. @@ -782,12 +804,13 @@ $$ ### to\_matrix - + 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). + * **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 (the default). + * **force\_serial** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if `True`, use an unthreaded implementation, regardless of the state of the [Qiskit threading-control environment variables](/start/configure-qiskit-local#environment-variables). By default, this will use threaded parallelism over the available CPUs. **Returns** @@ -800,7 +823,7 @@ $$ ### to\_operator - + Convert to a matrix Operator object **Return type** @@ -810,7 +833,7 @@ $$ ### transpose - + Return the transpose of the SparsePauliOp. diff --git a/docs/api/qiskit/qiskit.quantum_info.StabilizerState.mdx b/docs/api/qiskit/qiskit.quantum_info.StabilizerState.mdx index fc92d9295e9..417202eba8e 100644 --- a/docs/api/qiskit/qiskit.quantum_info.StabilizerState.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.StabilizerState.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.StabilizerState # StabilizerState - + 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"). @@ -83,25 +83,25 @@ python_api_name: qiskit.quantum_info.StabilizerState ### conjugate - + Return the conjugate of the operator. ### copy - + Make a copy of current operator. ### dims - + Return tuple of input dimension for specified subsystems. ### equiv - + Return True if the two generating sets generate the same stabilizer group. **Parameters** @@ -119,7 +119,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### evolve - + Evolve a stabilizer state by a Clifford operator. **Parameters** @@ -143,7 +143,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### expand - + Return the tensor product stabilizer state other ⊗ self. **Parameters** @@ -165,7 +165,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### expectation\_value - + Compute the expectation value of a Pauli operator. **Parameters** @@ -188,7 +188,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### from\_stabilizer\_list - + Create a stabilizer state from the collection of stabilizers. **Parameters** @@ -208,13 +208,13 @@ python_api_name: qiskit.quantum_info.StabilizerState ### is\_valid - + Return True if a valid StabilizerState. ### measure - + 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. @@ -236,7 +236,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### probabilities - + Return the subsystem measurement probability vector. Measurement probabilities are with respect to measurement in the computation (diagonal) basis. @@ -257,7 +257,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### probabilities\_dict - + Return the subsystem measurement probability dictionary. Measurement probabilities are with respect to measurement in the computation (diagonal) basis. @@ -280,7 +280,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### purity - + Return the purity of the quantum state, which equals to 1, since it is always a pure state. **Returns** @@ -298,7 +298,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### reset - + Reset state or subsystems to the 0-state. **Parameters** @@ -320,7 +320,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### sample\_counts - + Sample a dict of qubit measurement outcomes in the computational basis. **Parameters** @@ -345,7 +345,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### sample\_memory - + Sample a list of qubit measurement outcomes in the computational basis. **Parameters** @@ -370,13 +370,13 @@ python_api_name: qiskit.quantum_info.StabilizerState ### seed - + Set the seed for the quantum state RNG. ### tensor - + Return the tensor product stabilizer state self ⊗ other. **Parameters** @@ -398,7 +398,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### to\_operator - + Convert state to matrix operator class **Return type** @@ -408,7 +408,7 @@ python_api_name: qiskit.quantum_info.StabilizerState ### trace - + Return the trace of the stabilizer state as a density matrix, which equals to 1, since it is always a pure state. **Returns** diff --git a/docs/api/qiskit/qiskit.quantum_info.Statevector.mdx b/docs/api/qiskit/qiskit.quantum_info.Statevector.mdx index b78795c75a5..f8e8c1f94e5 100644 --- a/docs/api/qiskit/qiskit.quantum_info.Statevector.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.Statevector.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Statevector # Statevector - + Bases: `QuantumState`, `TolerancesMixin` Statevector class @@ -69,7 +69,7 @@ python_api_name: qiskit.quantum_info.Statevector ### conjugate - + Return the conjugate of the operator. **Return type** @@ -79,19 +79,19 @@ python_api_name: qiskit.quantum_info.Statevector ### copy - + Make a copy of current operator. ### dims - + Return tuple of input dimension for specified subsystems. ### draw - + Return a visualization of the Statevector. **repr**: ASCII TextMatrix of the state’s `__repr__`. @@ -141,7 +141,7 @@ python_api_name: qiskit.quantum_info.Statevector ### equiv - + Return True if other is equivalent as a statevector up to global phase. @@ -165,7 +165,7 @@ python_api_name: qiskit.quantum_info.Statevector ### evolve - + Evolve a quantum state by the operator. **Parameters** @@ -188,7 +188,7 @@ python_api_name: qiskit.quantum_info.Statevector ### expand - + Return the tensor product state other ⊗ self. **Parameters** @@ -210,7 +210,7 @@ python_api_name: qiskit.quantum_info.Statevector ### expectation\_value - + Compute the expectation value of an operator. **Parameters** @@ -229,7 +229,7 @@ python_api_name: qiskit.quantum_info.Statevector ### from\_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. @@ -253,7 +253,7 @@ python_api_name: qiskit.quantum_info.Statevector ### from\_int - + Return a computational basis statevector. **Parameters** @@ -279,7 +279,7 @@ python_api_name: qiskit.quantum_info.Statevector ### from\_label - + Return a tensor product of Pauli X,Y,Z eigenstates. | Label | Statevector | @@ -310,7 +310,7 @@ python_api_name: qiskit.quantum_info.Statevector ### inner - + Return the inner product of self and other as $\langle self| other \rangle$. **Parameters** @@ -332,7 +332,7 @@ python_api_name: qiskit.quantum_info.Statevector ### is\_valid - + Return True if a Statevector has norm 1. **Return type** @@ -342,7 +342,7 @@ python_api_name: qiskit.quantum_info.Statevector ### measure - + 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. @@ -364,7 +364,7 @@ python_api_name: qiskit.quantum_info.Statevector ### probabilities - + Return the subsystem measurement probability vector. Measurement probabilities are with respect to measurement in the computation (diagonal) basis. @@ -435,7 +435,7 @@ python_api_name: qiskit.quantum_info.Statevector ### probabilities\_dict - + Return the subsystem measurement probability dictionary. Measurement probabilities are with respect to measurement in the computation (diagonal) basis. @@ -458,7 +458,7 @@ python_api_name: qiskit.quantum_info.Statevector ### purity - + Return the purity of the quantum state. **Return type** @@ -468,7 +468,7 @@ python_api_name: qiskit.quantum_info.Statevector ### reset - + Reset state or subsystems to the 0-state. **Parameters** @@ -490,7 +490,7 @@ python_api_name: qiskit.quantum_info.Statevector ### 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$. @@ -506,7 +506,7 @@ python_api_name: qiskit.quantum_info.Statevector ### sample\_counts - + Sample a dict of qubit measurement outcomes in the computational basis. **Parameters** @@ -531,7 +531,7 @@ python_api_name: qiskit.quantum_info.Statevector ### sample\_memory - + Sample a list of qubit measurement outcomes in the computational basis. **Parameters** @@ -556,13 +556,13 @@ python_api_name: qiskit.quantum_info.Statevector ### seed - + Set the seed for the quantum state RNG. ### tensor - + Return the tensor product state self ⊗ other. **Parameters** @@ -584,7 +584,7 @@ python_api_name: qiskit.quantum_info.Statevector ### to\_dict - + 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. @@ -653,7 +653,7 @@ python_api_name: qiskit.quantum_info.Statevector ### to\_operator - + Convert state to a rank-1 projector operator **Return type** @@ -663,7 +663,7 @@ python_api_name: qiskit.quantum_info.Statevector ### trace - + Return the trace of the quantum state as a density matrix. **Return type** diff --git a/docs/api/qiskit/qiskit.quantum_info.Stinespring.mdx b/docs/api/qiskit/qiskit.quantum_info.Stinespring.mdx index bcf8b23d6fe..d93651f1073 100644 --- a/docs/api/qiskit/qiskit.quantum_info.Stinespring.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.Stinespring.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Stinespring # Stinespring - + Bases: `QuantumChannel` Stinespring representation of a quantum channel. @@ -91,7 +91,7 @@ $$ ### adjoint - + Return the adjoint quantum channel. @@ -105,7 +105,7 @@ $$ ### compose - + Return the operator composition with another Stinespring. **Parameters** @@ -135,7 +135,7 @@ $$ ### conjugate - + Return the conjugate quantum channel. @@ -145,13 +145,13 @@ $$ ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -174,7 +174,7 @@ $$ ### expand - + Return the reverse-order tensor product with another Stinespring. **Parameters** @@ -194,13 +194,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_cp - + Test if Choi-matrix is completely-positive (CP) **Return type** @@ -210,13 +210,13 @@ $$ ### is\_cptp - + Return True if completely-positive trace-preserving. ### is\_tp - + Test if a channel is trace-preserving (TP) **Return type** @@ -226,7 +226,7 @@ $$ ### is\_unitary - + Return True if QuantumChannel is a unitary channel. **Return type** @@ -236,13 +236,13 @@ $$ ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the power of the quantum channel. **Parameters** @@ -268,7 +268,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -292,7 +292,7 @@ $$ ### tensor - + Return the tensor product with another Stinespring. **Parameters** @@ -316,7 +316,7 @@ $$ ### 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. @@ -336,7 +336,7 @@ $$ ### to\_operator - + Try to convert channel to a unitary representation Operator. **Return type** @@ -346,7 +346,7 @@ $$ ### transpose - + Return the transpose quantum channel. diff --git a/docs/api/qiskit/qiskit.quantum_info.SuperOp.mdx b/docs/api/qiskit/qiskit.quantum_info.SuperOp.mdx index c9b71d37222..1b8ff9550ee 100644 --- a/docs/api/qiskit/qiskit.quantum_info.SuperOp.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.SuperOp.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.SuperOp # SuperOp - + Bases: `QuantumChannel` Superoperator representation of a quantum channel. @@ -87,7 +87,7 @@ $$ ### adjoint - + Return the adjoint quantum channel. @@ -97,7 +97,7 @@ $$ ### compose - + Return the operator composition with another SuperOp. **Parameters** @@ -127,7 +127,7 @@ $$ ### conjugate - + Return the conjugate quantum channel. @@ -137,13 +137,13 @@ $$ ### copy - + Make a deep copy of current operator. ### dot - + Return the right multiplied operator self \* other. **Parameters** @@ -166,7 +166,7 @@ $$ ### expand - + Return the reverse-order tensor product with another SuperOp. **Parameters** @@ -186,13 +186,13 @@ $$ ### input\_dims - + Return tuple of input dimension for specified subsystems. ### is\_cp - + Test if Choi-matrix is completely-positive (CP) **Return type** @@ -202,7 +202,7 @@ $$ ### is\_cptp - + Return True if completely-positive trace-preserving (CPTP). **Return type** @@ -212,7 +212,7 @@ $$ ### is\_tp - + Test if a channel is trace-preserving (TP) **Return type** @@ -222,7 +222,7 @@ $$ ### is\_unitary - + Return True if QuantumChannel is a unitary channel. **Return type** @@ -232,13 +232,13 @@ $$ ### output\_dims - + Return tuple of output dimension for specified subsystems. ### power - + Return the power of the quantum channel. **Parameters** @@ -264,7 +264,7 @@ $$ ### reshape - + Return a shallow copy with reshaped input and output subsystem dimensions. **Parameters** @@ -288,7 +288,7 @@ $$ ### tensor - + Return the tensor product with another SuperOp. **Parameters** @@ -312,7 +312,7 @@ $$ ### 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. @@ -332,7 +332,7 @@ $$ ### to\_operator - + Try to convert channel to a unitary representation Operator. **Return type** @@ -342,7 +342,7 @@ $$ ### transpose - + Return the transpose quantum channel. diff --git a/docs/api/qiskit/qiskit.quantum_info.Z2Symmetries.mdx b/docs/api/qiskit/qiskit.quantum_info.Z2Symmetries.mdx index a472c14dd73..e79a45a4cd7 100644 --- a/docs/api/qiskit/qiskit.quantum_info.Z2Symmetries.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.Z2Symmetries.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.quantum_info.Z2Symmetries # Z2Symmetries - + 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. @@ -93,7 +93,7 @@ python_api_name: qiskit.quantum_info.Z2Symmetries ### convert\_clifford - + 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** @@ -111,7 +111,7 @@ python_api_name: qiskit.quantum_info.Z2Symmetries ### find\_z2\_symmetries - + Finds Z2 Pauli-type symmetries of a [`SparsePauliOp`](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp"). **Returns** @@ -125,7 +125,7 @@ python_api_name: qiskit.quantum_info.Z2Symmetries ### is\_empty - + Check the z2\_symmetries is empty or not. **Returns** @@ -139,7 +139,7 @@ python_api_name: qiskit.quantum_info.Z2Symmetries ### taper - + 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. @@ -161,7 +161,7 @@ python_api_name: qiskit.quantum_info.Z2Symmetries ### taper\_clifford - + 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** diff --git a/docs/api/qiskit/qiskit.quantum_info.pauli_basis.mdx b/docs/api/qiskit/qiskit.quantum_info.pauli_basis.mdx index df2e64e73ec..4bd67aea546 100644 --- a/docs/api/qiskit/qiskit.quantum_info.pauli_basis.mdx +++ b/docs/api/qiskit/qiskit.quantum_info.pauli_basis.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.quantum_info.pauli_basis # qiskit.quantum\_info.pauli\_basis - + Return the ordered PauliList for the n-qubit Pauli basis. **Parameters** diff --git a/docs/api/qiskit/qiskit.result.BaseReadoutMitigator.mdx b/docs/api/qiskit/qiskit.result.BaseReadoutMitigator.mdx index c494731b95e..f00677bee60 100644 --- a/docs/api/qiskit/qiskit.result.BaseReadoutMitigator.mdx +++ b/docs/api/qiskit/qiskit.result.BaseReadoutMitigator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.result.BaseReadoutMitigator # BaseReadoutMitigator - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Base readout error mitigator class. @@ -17,7 +17,7 @@ python_api_name: qiskit.result.BaseReadoutMitigator ### expectation\_value - + Calculate the expectation value of a diagonal Hermitian operator. **Parameters** @@ -39,7 +39,7 @@ python_api_name: qiskit.result.BaseReadoutMitigator ### quasi\_probabilities - + Convert counts to a dictionary of quasi-probabilities **Parameters** diff --git a/docs/api/qiskit/qiskit.result.CorrelatedReadoutMitigator.mdx b/docs/api/qiskit/qiskit.result.CorrelatedReadoutMitigator.mdx index d2f7696ea1e..2f78e29df5e 100644 --- a/docs/api/qiskit/qiskit.result.CorrelatedReadoutMitigator.mdx +++ b/docs/api/qiskit/qiskit.result.CorrelatedReadoutMitigator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.result.CorrelatedReadoutMitigator # CorrelatedReadoutMitigator - + Bases: [`BaseReadoutMitigator`](qiskit.result.BaseReadoutMitigator "qiskit.result.mitigation.base_readout_mitigator.BaseReadoutMitigator") N-qubit readout error mitigator. @@ -44,7 +44,7 @@ python_api_name: qiskit.result.CorrelatedReadoutMitigator ### assignment\_matrix - + 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$. @@ -64,7 +64,7 @@ python_api_name: qiskit.result.CorrelatedReadoutMitigator ### expectation\_value - + 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|$. @@ -92,7 +92,7 @@ python_api_name: qiskit.result.CorrelatedReadoutMitigator ### mitigation\_matrix - + 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$. @@ -112,7 +112,7 @@ python_api_name: qiskit.result.CorrelatedReadoutMitigator ### quasi\_probabilities - + Compute mitigated quasi probabilities value. **Parameters** @@ -135,7 +135,7 @@ python_api_name: qiskit.result.CorrelatedReadoutMitigator ### stddev\_upper\_bound - + Return an upper bound on standard deviation of expval estimator. **Parameters** diff --git a/docs/api/qiskit/qiskit.result.Counts.mdx b/docs/api/qiskit/qiskit.result.Counts.mdx index 0a7996d0419..75f527cf990 100644 --- a/docs/api/qiskit/qiskit.result.Counts.mdx +++ b/docs/api/qiskit/qiskit.result.Counts.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.result.Counts # Counts - + 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. @@ -67,7 +67,7 @@ python_api_name: qiskit.result.Counts ### hex\_outcomes - + Return a counts dictionary with hexadecimal string keys **Returns** @@ -87,7 +87,7 @@ python_api_name: qiskit.result.Counts ### int\_outcomes - + Build a counts dictionary with integer keys instead of count strings **Returns** @@ -113,7 +113,7 @@ python_api_name: qiskit.result.Counts ### most\_frequent - + Return the most frequent count **Returns** @@ -153,7 +153,7 @@ python_api_name: qiskit.result.Counts ### shots - + Return the number of shots diff --git a/docs/api/qiskit/qiskit.result.LocalReadoutMitigator.mdx b/docs/api/qiskit/qiskit.result.LocalReadoutMitigator.mdx index cce1a33d073..8612ab6a2c0 100644 --- a/docs/api/qiskit/qiskit.result.LocalReadoutMitigator.mdx +++ b/docs/api/qiskit/qiskit.result.LocalReadoutMitigator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.result.LocalReadoutMitigator # LocalReadoutMitigator - + Bases: [`BaseReadoutMitigator`](qiskit.result.BaseReadoutMitigator "qiskit.result.mitigation.base_readout_mitigator.BaseReadoutMitigator") 1-qubit tensor product readout error mitigator. @@ -45,7 +45,7 @@ python_api_name: qiskit.result.LocalReadoutMitigator ### assignment\_matrix - + 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$. @@ -65,7 +65,7 @@ python_api_name: qiskit.result.LocalReadoutMitigator ### expectation\_value - + 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|$. @@ -93,7 +93,7 @@ python_api_name: qiskit.result.LocalReadoutMitigator ### mitigation\_matrix - + 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$. @@ -113,7 +113,7 @@ python_api_name: qiskit.result.LocalReadoutMitigator ### quasi\_probabilities - + Compute mitigated quasi probabilities value. **Parameters** @@ -140,7 +140,7 @@ python_api_name: qiskit.result.LocalReadoutMitigator ### stddev\_upper\_bound - + Return an upper bound on standard deviation of expval estimator. **Parameters** diff --git a/docs/api/qiskit/qiskit.result.ProbDistribution.mdx b/docs/api/qiskit/qiskit.result.ProbDistribution.mdx index 7a1b0ee770c..def435e1c47 100644 --- a/docs/api/qiskit/qiskit.result.ProbDistribution.mdx +++ b/docs/api/qiskit/qiskit.result.ProbDistribution.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.result.ProbDistribution # ProbDistribution - + Bases: [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") A generic dict-like class for probability distributions. @@ -36,7 +36,7 @@ python_api_name: qiskit.result.ProbDistribution ### binary\_probabilities - + Build a probabilities dictionary with binary string keys **Parameters** @@ -76,7 +76,7 @@ python_api_name: qiskit.result.ProbDistribution ### hex\_probabilities - + Build a probabilities dictionary with hexadecimal string keys **Returns** diff --git a/docs/api/qiskit/qiskit.result.QuasiDistribution.mdx b/docs/api/qiskit/qiskit.result.QuasiDistribution.mdx index b89782f5a0e..d6549cd0d53 100644 --- a/docs/api/qiskit/qiskit.result.QuasiDistribution.mdx +++ b/docs/api/qiskit/qiskit.result.QuasiDistribution.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.result.QuasiDistribution # QuasiDistribution - + Bases: [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") A dict-like class for representing quasi-probabilities. @@ -50,7 +50,7 @@ python_api_name: qiskit.result.QuasiDistribution ### binary\_probabilities - + Build a quasi-probabilities dictionary with binary string keys **Parameters** @@ -90,7 +90,7 @@ python_api_name: qiskit.result.QuasiDistribution ### hex\_probabilities - + Build a quasi-probabilities dictionary with hexadecimal string keys **Returns** @@ -114,7 +114,7 @@ python_api_name: qiskit.result.QuasiDistribution ### nearest\_probability\_distribution - + Takes a quasiprobability distribution and maps it to the closest probability distribution as defined by the L2-norm. **Parameters** diff --git a/docs/api/qiskit/qiskit.result.Result.mdx b/docs/api/qiskit/qiskit.result.Result.mdx index c9d3932d32a..7d791f1bb04 100644 --- a/docs/api/qiskit/qiskit.result.Result.mdx +++ b/docs/api/qiskit/qiskit.result.Result.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.result.Result # Result - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Model for Results. @@ -77,7 +77,7 @@ python_api_name: qiskit.result.Result ### data - + 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. @@ -109,7 +109,7 @@ python_api_name: qiskit.result.Result ### from\_dict - + Create a new ExperimentResultData object from a dictionary. **Parameters** @@ -127,7 +127,7 @@ python_api_name: qiskit.result.Result ### get\_counts - + Get the histogram data of an experiment. **Parameters** @@ -149,7 +149,7 @@ python_api_name: qiskit.result.Result ### get\_memory - + 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** @@ -179,7 +179,7 @@ python_api_name: qiskit.result.Result ### get\_statevector - + Get the final statevector of an experiment. **Parameters** @@ -202,7 +202,7 @@ python_api_name: qiskit.result.Result ### get\_unitary - + Get the final unitary of an experiment. **Parameters** @@ -227,7 +227,7 @@ python_api_name: qiskit.result.Result ### to\_dict - + Return a dictionary format representation of the Result **Returns** diff --git a/docs/api/qiskit/qiskit.result.ResultError.mdx b/docs/api/qiskit/qiskit.result.ResultError.mdx index 566cddb830a..edff40fcbb0 100644 --- a/docs/api/qiskit/qiskit.result.ResultError.mdx +++ b/docs/api/qiskit/qiskit.result.ResultError.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.result.ResultError # qiskit.result.ResultError - + Exceptions raised due to errors in result output. It may be better for the Qiskit API to raise this exception. diff --git a/docs/api/qiskit/qiskit.synthesis.EvolutionSynthesis.mdx b/docs/api/qiskit/qiskit.synthesis.EvolutionSynthesis.mdx index 6ad1bd61648..d650507e1ef 100644 --- a/docs/api/qiskit/qiskit.synthesis.EvolutionSynthesis.mdx +++ b/docs/api/qiskit/qiskit.synthesis.EvolutionSynthesis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.EvolutionSynthesis # EvolutionSynthesis - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Interface for evolution synthesis algorithms. @@ -33,7 +33,7 @@ python_api_name: qiskit.synthesis.EvolutionSynthesis ### synthesize - + Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. **Parameters** diff --git a/docs/api/qiskit/qiskit.synthesis.LieTrotter.mdx b/docs/api/qiskit/qiskit.synthesis.LieTrotter.mdx index e35bf1e1c97..aed4d171297 100644 --- a/docs/api/qiskit/qiskit.synthesis.LieTrotter.mdx +++ b/docs/api/qiskit/qiskit.synthesis.LieTrotter.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.LieTrotter # LieTrotter - + Bases: [`ProductFormula`](qiskit.synthesis.ProductFormula "qiskit.synthesis.evolution.product_formula.ProductFormula") The Lie-Trotter product formula. @@ -56,7 +56,7 @@ $$ ### synthesize - + Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. **Parameters** diff --git a/docs/api/qiskit/qiskit.synthesis.MatrixExponential.mdx b/docs/api/qiskit/qiskit.synthesis.MatrixExponential.mdx index c133654f102..61785d90f6b 100644 --- a/docs/api/qiskit/qiskit.synthesis.MatrixExponential.mdx +++ b/docs/api/qiskit/qiskit.synthesis.MatrixExponential.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.MatrixExponential # MatrixExponential - + Bases: [`EvolutionSynthesis`](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.evolution.evolution_synthesis.EvolutionSynthesis") Exact operator evolution via matrix exponentiation and unitary synthesis. @@ -35,7 +35,7 @@ python_api_name: qiskit.synthesis.MatrixExponential ### synthesize - + Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. **Parameters** diff --git a/docs/api/qiskit/qiskit.synthesis.OneQubitEulerDecomposer.mdx b/docs/api/qiskit/qiskit.synthesis.OneQubitEulerDecomposer.mdx index 17ab8378a48..3bec1535fac 100644 --- a/docs/api/qiskit/qiskit.synthesis.OneQubitEulerDecomposer.mdx +++ b/docs/api/qiskit/qiskit.synthesis.OneQubitEulerDecomposer.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.OneQubitEulerDecomposer # OneQubitEulerDecomposer - + 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. @@ -32,7 +32,7 @@ python_api_name: qiskit.synthesis.OneQubitEulerDecomposer ### \_\_call\_\_ - + Decompose single qubit gate into a circuit. **Parameters** @@ -79,7 +79,7 @@ python_api_name: qiskit.synthesis.OneQubitEulerDecomposer ### angles - + Return the Euler angles for input array. **Parameters** @@ -97,7 +97,7 @@ python_api_name: qiskit.synthesis.OneQubitEulerDecomposer ### angles\_and\_phase - + Return the Euler angles and phase for input array. **Parameters** @@ -115,7 +115,7 @@ python_api_name: qiskit.synthesis.OneQubitEulerDecomposer ### build\_circuit - + Return the circuit or dag object from a list of gates. diff --git a/docs/api/qiskit/qiskit.synthesis.ProductFormula.mdx b/docs/api/qiskit/qiskit.synthesis.ProductFormula.mdx index 21e886eb463..c6426af02b5 100644 --- a/docs/api/qiskit/qiskit.synthesis.ProductFormula.mdx +++ b/docs/api/qiskit/qiskit.synthesis.ProductFormula.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.ProductFormula # ProductFormula - + Bases: [`EvolutionSynthesis`](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.evolution.evolution_synthesis.EvolutionSynthesis") Product formula base class for the decomposition of non-commuting operator exponentials. @@ -43,7 +43,7 @@ python_api_name: qiskit.synthesis.ProductFormula ### synthesize - + Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. **Parameters** diff --git a/docs/api/qiskit/qiskit.synthesis.QDrift.mdx b/docs/api/qiskit/qiskit.synthesis.QDrift.mdx index e021f71b94b..965bc02d35d 100644 --- a/docs/api/qiskit/qiskit.synthesis.QDrift.mdx +++ b/docs/api/qiskit/qiskit.synthesis.QDrift.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.QDrift # QDrift - + 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]. @@ -45,7 +45,7 @@ python_api_name: qiskit.synthesis.QDrift ### synthesize - + Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. **Parameters** diff --git a/docs/api/qiskit/qiskit.synthesis.SolovayKitaevDecomposition.mdx b/docs/api/qiskit/qiskit.synthesis.SolovayKitaevDecomposition.mdx index 238e093333f..6d8cae9778a 100644 --- a/docs/api/qiskit/qiskit.synthesis.SolovayKitaevDecomposition.mdx +++ b/docs/api/qiskit/qiskit.synthesis.SolovayKitaevDecomposition.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.SolovayKitaevDecomposition # SolovayKitaevDecomposition - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") The Solovay Kitaev discrete decomposition algorithm. @@ -23,7 +23,7 @@ python_api_name: qiskit.synthesis.SolovayKitaevDecomposition ### find\_basic\_approximation - + Finds gate in `self._basic_approximations` that best represents `sequence`. **Parameters** @@ -41,7 +41,7 @@ python_api_name: qiskit.synthesis.SolovayKitaevDecomposition ### load\_basic\_approximations - + Load basic approximations. **Parameters** @@ -63,7 +63,7 @@ python_api_name: qiskit.synthesis.SolovayKitaevDecomposition ### run - + Run the algorithm. **Parameters** diff --git a/docs/api/qiskit/qiskit.synthesis.SuzukiTrotter.mdx b/docs/api/qiskit/qiskit.synthesis.SuzukiTrotter.mdx index bd45acceb85..d72b141ff7c 100644 --- a/docs/api/qiskit/qiskit.synthesis.SuzukiTrotter.mdx +++ b/docs/api/qiskit/qiskit.synthesis.SuzukiTrotter.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.SuzukiTrotter # SuzukiTrotter - + Bases: [`ProductFormula`](qiskit.synthesis.ProductFormula "qiskit.synthesis.evolution.product_formula.ProductFormula") The (higher order) Suzuki-Trotter product formula. @@ -63,7 +63,7 @@ $$ ### synthesize - + Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. **Parameters** diff --git a/docs/api/qiskit/qiskit.synthesis.TwoQubitBasisDecomposer.mdx b/docs/api/qiskit/qiskit.synthesis.TwoQubitBasisDecomposer.mdx index f79e68b0e66..a43a290173b 100644 --- a/docs/api/qiskit/qiskit.synthesis.TwoQubitBasisDecomposer.mdx +++ b/docs/api/qiskit/qiskit.synthesis.TwoQubitBasisDecomposer.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.TwoQubitBasisDecomposer # TwoQubitBasisDecomposer - + 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. @@ -22,7 +22,7 @@ python_api_name: qiskit.synthesis.TwoQubitBasisDecomposer ### \_\_call\_\_ - + Decompose a two-qubit `unitary` over fixed basis and $SU(2)$ using the best approximation given that each basis application has a finite `basis_fidelity`. **Parameters** @@ -30,6 +30,7 @@ python_api_name: qiskit.synthesis.TwoQubitBasisDecomposer * **unitary** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") *or ndarray*) – $4 \times 4$ unitary to synthesize. * **basis\_fidelity** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *or None*) – Fidelity to be assumed for applications of KAK Gate. If given, overrides `basis_fidelity` given at init. * **approximate** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Approximates if basis fidelities are less than 1.0. + * **use\_dag** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If true a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") is returned instead of a `QuantumCircuit` when this class is called. * **\_num\_basis\_uses** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – force a particular approximation by passing a number in \[0, 3]. **Returns** @@ -49,7 +50,7 @@ python_api_name: qiskit.synthesis.TwoQubitBasisDecomposer ### decomp0 - + Decompose target $\sim U_d(x, y, z)$ with $0$ uses of the basis gate. Result $U_r$ has trace: $$ @@ -62,7 +63,7 @@ $$ ### decomp1 - + Decompose target $\sim U_d(x, y, z)$ with $1$ use of the basis gate $\sim U_d(a, b, c)$. Result $U_r$ has trace: $$ @@ -75,7 +76,7 @@ $$ ### decomp2\_supercontrolled - + Decompose target $\sim U_d(x, y, z)$ with $2$ uses of the basis gate. For supercontrolled basis $\sim U_d(\pi/4, b, 0)$, all b, result $U_r$ has trace @@ -89,19 +90,19 @@ $$ ### decomp3\_supercontrolled - + Decompose target with $3$ uses of the basis. This is an exact decomposition for supercontrolled basis $\sim U_d(\pi/4, b, 0)$, all b, and any target. No guarantees for non-supercontrolled basis. ### num\_basis\_gates - + Computes the number of basis gates needed in a decomposition of input unitary ### traces - + Give the expected traces $\Big\vert\text{Tr}(U \cdot U_\text{target}^{\dag})\Big\vert$ for a different number of basis gates. diff --git a/docs/api/qiskit/qiskit.synthesis.TwoQubitWeylDecomposition.mdx b/docs/api/qiskit/qiskit.synthesis.TwoQubitWeylDecomposition.mdx index 19893280f59..b7a76e0d36b 100644 --- a/docs/api/qiskit/qiskit.synthesis.TwoQubitWeylDecomposition.mdx +++ b/docs/api/qiskit/qiskit.synthesis.TwoQubitWeylDecomposition.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.TwoQubitWeylDecomposition # TwoQubitWeylDecomposition - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Two-qubit Weyl decomposition. @@ -32,9 +32,7 @@ $$ \pi /4 \geq a \geq b \geq |c| $$ - This is an abstract factory class that instantiates itself as specialized subclasses based on the fidelity, such that the approximation error from specialization has an average gate fidelity at least as high as requested. The specialized subclasses have unique canonical representations thus avoiding problems of numerical stability. - - Passing non-None fidelity to specializations is treated as an assertion, raising QiskitError if forcing the specialization is more approximate than asserted. + This class avoids some problems of numerical instability near high-symmetry loci within the Weyl chamber. If there is a high-symmetry gate “nearby” (in terms of the requested average gate fidelity), then it return a canonicalized decomposition of that high-symmetry gate. **References** @@ -42,11 +40,6 @@ $$ 2. B. Kraus, J. I. Cirac, *Optimal Creation of Entanglement Using a Two-Qubit Gate*, [arXiv:0011050 \[quant-ph\]](https://arxiv.org/abs/quant-ph/0011050) 3. B. Drury, P. J. Love, *Constructive Quantum Shannon Decomposition from Cartan Involutions*, [arXiv:0806.4015 \[quant-ph\]](https://arxiv.org/abs/0806.4015) - **Parameters** - - * **unitary\_matrix** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – The unitary to decompose. - * **fidelity** – The target fidelity of the decomposed operation. - ## Attributes ### a @@ -97,7 +90,7 @@ $$ ### actual\_fidelity - + Calculates the actual fidelity of the decomposed circuit to the input unitary. **Return type** @@ -107,7 +100,7 @@ $$ ### circuit - + Returns Weyl decomposition in circuit form. **Return type** @@ -117,18 +110,24 @@ $$ ### from\_bytes - + Decode bytes into [`TwoQubitWeylDecomposition`](#qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.TwoQubitWeylDecomposition"). **Return type** - [*TwoQubitWeylDecomposition*](#qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.two_qubit.two_qubit_decompose.TwoQubitWeylDecomposition") + [TwoQubitWeylDecomposition](#qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.TwoQubitWeylDecomposition") ### specialize - - Make changes to the decomposition to comply with any specialization. + + Make changes to the decomposition to comply with any specializations. + + This method will always raise a `NotImplementedError` because there are no specializations to comply with in the current implementation. + + + The method `qiskit.synthesis.two_qubit.two_qubit_decompose.TwoQubitWeylDecomposition.specialize()` is deprecated as of qiskit 1.1.0. It will be removed in the 2.0.0 release. + diff --git a/docs/api/qiskit/qiskit.synthesis.XXDecomposer.mdx b/docs/api/qiskit/qiskit.synthesis.XXDecomposer.mdx index ff52d7fe9dd..86a352a60b3 100644 --- a/docs/api/qiskit/qiskit.synthesis.XXDecomposer.mdx +++ b/docs/api/qiskit/qiskit.synthesis.XXDecomposer.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.XXDecomposer # XXDecomposer - + 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$). @@ -26,7 +26,7 @@ python_api_name: qiskit.synthesis.XXDecomposer ### \_\_call\_\_ - + Fashions a circuit which (perhaps approximately) models the special unitary operation `unitary`, using the circuit templates supplied at initialization as `embodiments`. The routine uses `basis_fidelity` to select the optimal circuit template, including when performing exact synthesis; the contents of `basis_fidelity` is a dictionary mapping interaction strengths (scaled so that $CX = RZX(\pi/2)$ corresponds to $\pi/2$) to circuit fidelities. **Parameters** @@ -34,6 +34,7 @@ python_api_name: qiskit.synthesis.XXDecomposer * **unitary** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") *or ndarray*) – $4 \times 4$ unitary to synthesize. * **basis\_fidelity** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *or*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Fidelity of basis gates. 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}`. If given, overrides the basis\_fidelity given at init. * **approximate** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Approximates if basis fidelities are less than 1.0 . + * **use\_dag** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If true a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") is returned instead of a `QuantumCircuit` when this class is called. **Returns** @@ -48,7 +49,7 @@ python_api_name: qiskit.synthesis.XXDecomposer ### num\_basis\_gates - + Counts the number of gates that would be emitted during re-synthesis. diff --git a/docs/api/qiskit/qiskit.synthesis.unitary.aqc.AQC.mdx b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.AQC.mdx index de001455679..552307e10c9 100644 --- a/docs/api/qiskit/qiskit.synthesis.unitary.aqc.AQC.mdx +++ b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.AQC.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.AQC # AQC - + 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: @@ -27,7 +27,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.AQC ### compile\_unitary - + 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** diff --git a/docs/api/qiskit/qiskit.synthesis.unitary.aqc.ApproximateCircuit.mdx b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.ApproximateCircuit.mdx index fe8ed3268f1..65c027e724d 100644 --- a/docs/api/qiskit/qiskit.synthesis.unitary.aqc.ApproximateCircuit.mdx +++ b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.ApproximateCircuit.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit # ApproximateCircuit - + 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. @@ -23,7 +23,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -37,13 +37,13 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -57,12 +57,12 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -77,9 +77,9 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -88,12 +88,36 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.synthesis.unitary.aqc.ApproximateCircuit.num_input_vars "qiskit.synthesis.unitary.aqc.ApproximateCircuit.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.synthesis.unitary.aqc.ApproximateCircuit.num_captured_vars "qiskit.synthesis.unitary.aqc.ApproximateCircuit.num_captured_vars") must be zero. + + ### num\_parameters @@ -106,6 +130,14 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -187,7 +219,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### thetas @@ -200,11 +232,41 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit a vector of parameters of this circuit. + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.synthesis.unitary.aqc.ApproximateCircuit.unit "qiskit.synthesis.unitary.aqc.ApproximateCircuit.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.synthesis.unitary.aqc.ApproximateCircuit.duration "qiskit.synthesis.unitary.aqc.ApproximateCircuit.duration") is specified in. + + ## Methods ### build - + **Constructs this circuit out of the parameters(thetas). Parameter values must be set before** constructing the circuit. diff --git a/docs/api/qiskit/qiskit.synthesis.unitary.aqc.ApproximatingObjective.mdx b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.ApproximatingObjective.mdx index d81eb8d8a18..5dc0fb0c764 100644 --- a/docs/api/qiskit/qiskit.synthesis.unitary.aqc.ApproximatingObjective.mdx +++ b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.ApproximatingObjective.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximatingObjective # ApproximatingObjective - + 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. @@ -31,7 +31,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximatingObjective ### gradient - + Computes a gradient with respect to parameters given a vector of parameter values. **Parameters** @@ -49,7 +49,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.ApproximatingObjective ### objective - + Computes a value of the objective function given a vector of parameter values. **Parameters** diff --git a/docs/api/qiskit/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.mdx b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.mdx index 483ae5db9ca..711edca7bd9 100644 --- a/docs/api/qiskit/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.mdx +++ b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit # CNOTUnitCircuit - + 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. @@ -29,7 +29,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit ### ancillas - Returns a list of ancilla bits in the order that the registers were added. + A list of `AncillaQubit`s in the order that they were added. You should not mutate this. ### calibrations @@ -43,13 +43,13 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit ### clbits - Returns a list of classical bits in the order that the registers were added. + A list of `Clbit`s in the order that they were added. You should not mutate this. ### data - Return the circuit data (instructions and context). + The circuit data (instructions and context). **Returns** @@ -63,12 +63,12 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit ### global\_phase - Return the global phase of the current circuit scope in radians. + The global phase of the current circuit scope in radians. ### instances - + ### layout @@ -83,9 +83,9 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit ### metadata - The user provided metadata associated with the circuit. + Arbitrary user-defined metadata for 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. + Qiskit will not examine the content of this mapping, but it will pass it through the transpiler and reattach it to the output, so you can track your own metadata. ### num\_ancillas @@ -94,12 +94,36 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit Return the number of ancilla qubits. + ### num\_captured\_vars + + + The number of real-time classical variables in the circuit marked as captured from an enclosing scope. + + This is the length of the `iter_captured_vars()` iterable. If this is non-zero, [`num_input_vars`](#qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.num_input_vars "qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.num_input_vars") must be zero. + + ### num\_clbits Return number of classical bits. + ### num\_declared\_vars + + + The number of real-time classical variables in the circuit that are declared by this circuit scope, excluding inputs or captures. + + This is the length of the `iter_declared_vars()` iterable. + + + ### num\_input\_vars + + + The number of real-time classical variables in the circuit marked as circuit inputs. + + This is the length of the `iter_input_vars()` iterable. If this is non-zero, [`num_captured_vars`](#qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.num_captured_vars "qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.num_captured_vars") must be zero. + + ### num\_parameters @@ -112,6 +136,14 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit Return number of qubits. + ### num\_vars + + + The number of real-time classical variables in the circuit. + + This is the length of the `iter_vars()` iterable. + + ### op\_start\_times @@ -193,7 +225,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit ### qubits - Returns a list of quantum bits in the order that the registers were added. + A list of `Qubit`s in the order that they were added. You should not mutate this. ### thetas @@ -206,11 +238,41 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit Parameters of the rotation gates in this circuit. + ### name + + + A human-readable name for the circuit. + + + ### qregs + + + A list of the `QuantumRegister`s in this circuit. You should not mutate this. + + + ### cregs + + + A list of the `ClassicalRegister`s in this circuit. You should not mutate this. + + + ### duration + + + The total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by [`unit`](#qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.unit "qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.unit"). + + + ### unit + + + The unit that [`duration`](#qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.duration "qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.duration") is specified in. + + ## Methods ### build - + **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/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.mdx b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.mdx index 5e5c2a3dcfa..34c2e1b7d15 100644 --- a/docs/api/qiskit/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.mdx +++ b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitObjective # CNOTUnitObjective - + 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. diff --git a/docs/api/qiskit/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.mdx b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.mdx index 434eaed69ac..d348762b6f1 100644 --- a/docs/api/qiskit/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.mdx +++ b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective # DefaultCNOTUnitObjective - + 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. @@ -42,7 +42,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective ### gradient - + Computes a gradient with respect to parameters given a vector of parameter values. **Parameters** @@ -60,7 +60,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective ### objective - + Computes a value of the objective function given a vector of parameter values. **Parameters** diff --git a/docs/api/qiskit/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.mdx b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.mdx index 404ef337a7a..4df9e2acf1f 100644 --- a/docs/api/qiskit/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.mdx +++ b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective # FastCNOTUnitObjective - + 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. @@ -42,7 +42,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective ### gradient - + Computes the gradient of objective function. See description of the base class method. **Return type** @@ -52,7 +52,7 @@ python_api_name: qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective ### objective - + Computes the objective function and some intermediate data for the subsequent gradient computation. See description of the base class method. **Return type** diff --git a/docs/api/qiskit/qiskit.synthesis.unitary.aqc.mdx b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.mdx index af1b2d69e5d..dd3162bb2ba 100644 --- a/docs/api/qiskit/qiskit.synthesis.unitary.aqc.mdx +++ b/docs/api/qiskit/qiskit.synthesis.unitary.aqc.mdx @@ -10,11 +10,9 @@ python_api_name: qiskit.synthesis.unitary.aqc -# qiskit.synthesis.unitary.aqc - -## Approximate Quantum Compiler +# Approximate Quantum Compiler @@ -22,7 +20,7 @@ python_api_name: qiskit.synthesis.unitary.aqc Implementation of Approximate Quantum Compiler as described in the paper \[1]. -### Interface +## 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: @@ -36,7 +34,7 @@ The main public interface of this module is reached by passing `unitary_synthesi | [`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 +## 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. @@ -83,7 +81,7 @@ A basic usage of the AQC algorithm should consist of the following steps: unitary = ... # Define a number of qubits for the algorithm, at least 3 qubits -num_qubits = int(round(np.log2(unitary.shape[0]))) +num_qubits = round(math.log2(unitary.shape[0])) # Choose a layout of the CNOT structure for the approximate circuit, e.g. ``spin`` for # a linear layout. @@ -127,9 +125,9 @@ Now `approximate_circuit` is a circuit that approximates the target unitary to a 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 +### make\_cnot\_network - + 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** diff --git a/docs/api/qiskit/qiskit.transpiler.AnalysisPass.mdx b/docs/api/qiskit/qiskit.transpiler.AnalysisPass.mdx index 830a039a689..d8124491968 100644 --- a/docs/api/qiskit/qiskit.transpiler.AnalysisPass.mdx +++ b/docs/api/qiskit/qiskit.transpiler.AnalysisPass.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.AnalysisPass # AnalysisPass - + Bases: `BasePass` An analysis pass: change property set, not DAG. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.AnalysisPass ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.AnalysisPass ### name - + Name of the pass. **Return type** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.AnalysisPass ### run - + Run a pass on the DAGCircuit. This is implemented by the pass developer. **Parameters** @@ -79,7 +79,7 @@ python_api_name: qiskit.transpiler.AnalysisPass ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.CouplingMap.mdx b/docs/api/qiskit/qiskit.transpiler.CouplingMap.mdx index 5a29b1e165b..fa6581e7449 100644 --- a/docs/api/qiskit/qiskit.transpiler.CouplingMap.mdx +++ b/docs/api/qiskit/qiskit.transpiler.CouplingMap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.CouplingMap # CouplingMap - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Directed graph specifying fixed coupling. @@ -58,7 +58,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### add\_edge - + Add directed edge to coupling graph. src (int): source physical qubit dst (int): destination physical qubit @@ -66,7 +66,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### add\_physical\_qubit - + Add a physical qubit to the coupling graph as a node. physical\_qubit (int): An integer representing a physical qubit. @@ -78,7 +78,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### 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. @@ -86,7 +86,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### 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: @@ -142,7 +142,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### distance - + Returns the undirected distance between physical\_qubit1 and physical\_qubit2. **Parameters** @@ -165,7 +165,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### 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)") function from the `rustworkx` package to draw the [`CouplingMap`](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object. @@ -181,7 +181,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### from\_full - + Return a fully connected coupling map on n qubits. **Return type** @@ -191,7 +191,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### from\_grid - + Return a coupling map of qubits connected on a grid of num\_rows x num\_columns. **Return type** @@ -201,7 +201,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### from\_heavy\_hex - + Return a heavy hexagon graph coupling map. A heavy hexagon graph is described in: @@ -224,7 +224,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### from\_heavy\_square - + Return a heavy square graph coupling map. A heavy square graph is described in: @@ -247,7 +247,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### from\_hexagonal\_lattice - + Return a hexagonal lattice graph coupling map. **Parameters** @@ -267,7 +267,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### from\_line - + Return a coupling map of n qubits connected in a line. **Return type** @@ -277,7 +277,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### from\_ring - + Return a coupling map of n qubits connected to each of their neighbors in a ring. **Return type** @@ -287,7 +287,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### get\_edges - + Gets the list of edges in the coupling graph. **Returns** @@ -301,7 +301,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### is\_connected - + Test if the graph is connected. Return True if connected, False otherwise @@ -309,19 +309,19 @@ python_api_name: qiskit.transpiler.CouplingMap ### largest\_connected\_component - + Return a set of qubits in the largest connected component. ### make\_symmetric - + Convert uni-directional edges into bi-directional. ### neighbors - + 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. @@ -329,7 +329,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### reduce - + Returns a reduced coupling map that corresponds to the subgraph of qubits selected in the mapping. **Parameters** @@ -352,7 +352,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### shortest\_undirected\_path - + Returns the shortest undirected path between physical\_qubit1 and physical\_qubit2. **Parameters** @@ -375,7 +375,7 @@ python_api_name: qiskit.transpiler.CouplingMap ### size - + Return the number of physical qubits in this graph. diff --git a/docs/api/qiskit/qiskit.transpiler.InstructionDurations.mdx b/docs/api/qiskit/qiskit.transpiler.InstructionDurations.mdx index 432804c6aac..577c3e2aa23 100644 --- a/docs/api/qiskit/qiskit.transpiler.InstructionDurations.mdx +++ b/docs/api/qiskit/qiskit.transpiler.InstructionDurations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.InstructionDurations # InstructionDurations - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Helper class to provide durations of instructions for scheduling. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.InstructionDurations ### from\_backend - + Construct an [`InstructionDurations`](#qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object from the backend. **Parameters** @@ -41,7 +41,7 @@ python_api_name: qiskit.transpiler.InstructionDurations ### get - + Get the duration of the instruction with the name, qubits, and parameters. Some instructions may have a parameter dependent duration. @@ -68,7 +68,7 @@ python_api_name: qiskit.transpiler.InstructionDurations ### units\_used - + Get the set of all units used in this instruction durations. **Returns** @@ -82,7 +82,7 @@ python_api_name: qiskit.transpiler.InstructionDurations ### update - + Update self with inst\_durations (inst\_durations overwrite self). **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.InstructionProperties.mdx b/docs/api/qiskit/qiskit.transpiler.InstructionProperties.mdx index 762e5d9907c..5982dfecf08 100644 --- a/docs/api/qiskit/qiskit.transpiler.InstructionProperties.mdx +++ b/docs/api/qiskit/qiskit.transpiler.InstructionProperties.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.InstructionProperties # InstructionProperties - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") A representation of the properties of a gate implementation. diff --git a/docs/api/qiskit/qiskit.transpiler.Layout.mdx b/docs/api/qiskit/qiskit.transpiler.Layout.mdx index 74bef73eb59..af6f13b0545 100644 --- a/docs/api/qiskit/qiskit.transpiler.Layout.mdx +++ b/docs/api/qiskit/qiskit.transpiler.Layout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.Layout # Layout - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Two-ways dict to represent a Layout. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.Layout ### add - + 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** @@ -30,17 +30,17 @@ python_api_name: qiskit.transpiler.Layout ### add\_register - + 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’). + **reg** ([*Register*](circuit#qiskit.circuit.Register "qiskit.circuit.Register")) – A (qu)bit Register. For example, QuantumRegister(3, ‘qr’). ### combine\_into\_edge\_map - + Combines self and another\_layout into an “edge map”. For example: @@ -71,15 +71,36 @@ python_api_name: qiskit.transpiler.Layout [**LayoutError**](transpiler#qiskit.transpiler.LayoutError "qiskit.transpiler.LayoutError") – another\_layout can be bigger than self, but not smaller. Otherwise, raises. + ### compose + + + Compose this layout with another layout. + + If this layout represents a mapping from the P-qubits to the positions of the Q-qubits, and the other layout represents a mapping from the Q-qubits to the positions of the R-qubits, then the composed layout represents a mapping from the P-qubits to the positions of the R-qubits. + + **Parameters** + + * **other** ([*Layout*](#qiskit.transpiler.Layout "qiskit.transpiler.layout.Layout")) – The existing [`Layout`](#qiskit.transpiler.Layout "qiskit.transpiler.Layout") to compose this [`Layout`](#qiskit.transpiler.Layout "qiskit.transpiler.Layout") with. + * **qubits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit")*]*) – A list of [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit") objects over which `other` is defined, used to establish the correspondence between the positions of the `other` qubits and the actual qubits. + + **Returns** + + A new layout object the represents this layout composed with the `other` layout. + + **Return type** + + [*Layout*](#qiskit.transpiler.Layout "qiskit.transpiler.layout.Layout") + + ### copy - + Returns a copy of a Layout instance. ### from\_dict - + Populates a Layout from a dictionary. The dictionary must be a bijective mapping between virtual qubits (tuple) and physical qubits (int). @@ -113,7 +134,7 @@ python_api_name: qiskit.transpiler.Layout ### from\_intlist - + Converts a list of integers to a Layout mapping virtual qubits (index of the list) to physical qubits (the list values). **Parameters** @@ -136,7 +157,7 @@ python_api_name: qiskit.transpiler.Layout ### from\_qubit\_list - + Populates a Layout from a list containing virtual qubits, Qubit or None. **Parameters** @@ -159,7 +180,7 @@ python_api_name: qiskit.transpiler.Layout ### generate\_trivial\_layout - + Creates a trivial (“one-to-one”) Layout with the registers and qubits in regs. **Parameters** @@ -177,38 +198,55 @@ python_api_name: qiskit.transpiler.Layout ### get\_physical\_bits - + Returns the dictionary where the keys are physical (qu)bits and the values are virtual (qu)bits. ### 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 - + Returns the dictionary where the keys are virtual (qu)bits and the values are physical (qu)bits. + ### inverse + + + Finds the inverse of this layout. + + This is possible when the layout is a bijective mapping, however the input and the output qubits may be different (in particular, this layout may be the mapping from the extended-with-ancillas virtual qubits to physical qubits). Thus, if this layout represents a mapping from the P-qubits to the positions of the Q-qubits, the inverse layout represents a mapping from the Q-qubits to the positions of the P-qubits. + + **Parameters** + + * **source\_qubits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit")*]*) – A list of [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit") objects representing the domain of the layout. + * **target\_qubits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Qubit*](circuit#qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit")*]*) – A list of [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit") objects representing the image of the layout. + + **Returns** + + A new layout object the represents the inverse of this layout. + + ### order\_based\_on\_type - + decides which one is physical/virtual based on the type. Returns (virtual, physical) ### reorder\_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. + **bits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Bit*](circuit#qiskit.circuit.Bit "qiskit.circuit.Bit")*]*) – the bits to reorder. **Returns** @@ -221,7 +259,7 @@ python_api_name: qiskit.transpiler.Layout ### swap - + Swaps the map between left and right. **Parameters** @@ -233,5 +271,15 @@ python_api_name: qiskit.transpiler.Layout [**LayoutError**](transpiler#qiskit.transpiler.LayoutError "qiskit.transpiler.LayoutError") – If left and right have not the same type. + + ### to\_permutation + + + Creates a permutation corresponding to this layout. + + This is possible when the layout is a bijective mapping with the same source and target qubits (for instance, a “final\_layout” corresponds to a permutation of the physical circuit qubits). If this layout is a mapping from qubits to their new positions, the resulting permutation describes which qubits occupy the positions 0, 1, 2, etc. after applying the permutation. + + For example, suppose that the list of qubits is `[qr_0, qr_1, qr_2]`, and the layout maps `qr_0` to `2`, `qr_1` to `0`, and `qr_2` to `1`. In terms of positions in `qubits`, this maps `0` to `2`, `1` to `0` and `2` to `1`, with the corresponding permutation being `[1, 2, 0]`. + diff --git a/docs/api/qiskit/qiskit.transpiler.PassManager.mdx b/docs/api/qiskit/qiskit.transpiler.PassManager.mdx index ae3f37121ad..e4936fc75f8 100644 --- a/docs/api/qiskit/qiskit.transpiler.PassManager.mdx +++ b/docs/api/qiskit/qiskit.transpiler.PassManager.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.PassManager # PassManager - + Bases: [`BasePassManager`](qiskit.passmanager.BasePassManager "qiskit.passmanager.passmanager.BasePassManager") Manager for a set of Passes and their scheduling during transpilation. @@ -24,7 +24,7 @@ python_api_name: qiskit.transpiler.PassManager ### append - + Append a Pass Set to the schedule of passes. **Parameters** @@ -38,7 +38,7 @@ python_api_name: qiskit.transpiler.PassManager ### draw - + 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. @@ -64,7 +64,7 @@ python_api_name: qiskit.transpiler.PassManager ### remove - + Removes a particular pass in the scheduler. **Parameters** @@ -78,7 +78,7 @@ python_api_name: qiskit.transpiler.PassManager ### replace - + Replace a particular pass in the scheduler. **Parameters** @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.PassManager ### run - + Run all the passes on the specified `circuits`. **Parameters** @@ -141,7 +141,7 @@ python_api_name: qiskit.transpiler.PassManager ### 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** diff --git a/docs/api/qiskit/qiskit.transpiler.PassManagerConfig.mdx b/docs/api/qiskit/qiskit.transpiler.PassManagerConfig.mdx index d0ffb2418cf..c2340dadb5d 100644 --- a/docs/api/qiskit/qiskit.transpiler.PassManagerConfig.mdx +++ b/docs/api/qiskit/qiskit.transpiler.PassManagerConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.PassManagerConfig # PassManagerConfig - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Pass Manager Configuration. @@ -40,7 +40,7 @@ python_api_name: qiskit.transpiler.PassManagerConfig ### from\_backend - + 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. diff --git a/docs/api/qiskit/qiskit.transpiler.StagedPassManager.mdx b/docs/api/qiskit/qiskit.transpiler.StagedPassManager.mdx index ab6fa27e6ac..82442a76ff1 100644 --- a/docs/api/qiskit/qiskit.transpiler.StagedPassManager.mdx +++ b/docs/api/qiskit/qiskit.transpiler.StagedPassManager.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.StagedPassManager # StagedPassManager - + Bases: [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.passmanager.PassManager") A pass manager pipeline built from individual stages. @@ -64,7 +64,7 @@ python_api_name: qiskit.transpiler.StagedPassManager ### append - + Append a Pass Set to the schedule of passes. **Parameters** @@ -78,13 +78,13 @@ python_api_name: qiskit.transpiler.StagedPassManager ### draw - + Draw the staged pass manager. ### remove - + Removes a particular pass in the scheduler. **Parameters** @@ -98,7 +98,7 @@ python_api_name: qiskit.transpiler.StagedPassManager ### replace - + Replace a particular pass in the scheduler. **Parameters** @@ -109,7 +109,7 @@ python_api_name: qiskit.transpiler.StagedPassManager ### run - + Run all the passes on the specified `circuits`. **Parameters** @@ -161,7 +161,7 @@ python_api_name: qiskit.transpiler.StagedPassManager ### 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** diff --git a/docs/api/qiskit/qiskit.transpiler.Target.mdx b/docs/api/qiskit/qiskit.transpiler.Target.mdx index 6feb56ad759..119547304c0 100644 --- a/docs/api/qiskit/qiskit.transpiler.Target.mdx +++ b/docs/api/qiskit/qiskit.transpiler.Target.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.Target # Target - + 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. @@ -159,7 +159,7 @@ python_api_name: qiskit.transpiler.Target ### add\_instruction - + 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: @@ -198,7 +198,7 @@ python_api_name: qiskit.transpiler.Target ### build\_coupling\_map - + 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. @@ -226,7 +226,7 @@ python_api_name: qiskit.transpiler.Target ### durations - + Get an InstructionDurations object from the target **Returns** @@ -242,7 +242,7 @@ python_api_name: qiskit.transpiler.Target ### from\_configuration - + 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"). @@ -283,7 +283,7 @@ python_api_name: qiskit.transpiler.Target ### get\_calibration - + 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. @@ -306,7 +306,7 @@ python_api_name: qiskit.transpiler.Target ### get\_non\_global\_operation\_names - + 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). @@ -326,7 +326,7 @@ python_api_name: qiskit.transpiler.Target ### has\_calibration - + Return whether the instruction (operation + qubits) defines a calibration. **Parameters** @@ -345,7 +345,7 @@ python_api_name: qiskit.transpiler.Target ### instruction\_properties - + 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: @@ -383,7 +383,7 @@ python_api_name: qiskit.transpiler.Target ### instruction\_schedule\_map - + Return an [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions in the target with a pulse schedule defined. **Returns** @@ -397,7 +397,7 @@ python_api_name: qiskit.transpiler.Target ### instruction\_supported - + Return whether the instruction (operation + qubits) is supported by the target **Parameters** @@ -436,15 +436,15 @@ python_api_name: qiskit.transpiler.Target ### items - + ### keys - + ### operation\_from\_name - + Get the operation class object for a given name **Parameters** @@ -462,7 +462,7 @@ python_api_name: qiskit.transpiler.Target ### operation\_names\_for\_qargs - + Get the operation names for a specified qargs tuple **Parameters** @@ -484,7 +484,7 @@ python_api_name: qiskit.transpiler.Target ### operations\_for\_qargs - + Get the operation class object for a specified qargs tuple **Parameters** @@ -506,7 +506,7 @@ python_api_name: qiskit.transpiler.Target ### qargs\_for\_operation\_name - + Get the qargs for a given operation name **Parameters** @@ -524,7 +524,7 @@ python_api_name: qiskit.transpiler.Target ### timing\_constraints - + Get an `TimingConstraints` object from the target **Returns** @@ -538,7 +538,7 @@ python_api_name: qiskit.transpiler.Target ### update\_from\_instruction\_schedule\_map - + 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. @@ -570,7 +570,7 @@ python_api_name: qiskit.transpiler.Target ### update\_instruction\_properties - + Update the property object for an instruction qarg pair already in the Target **Parameters** @@ -586,6 +586,6 @@ python_api_name: qiskit.transpiler.Target ### values - + diff --git a/docs/api/qiskit/qiskit.transpiler.TransformationPass.mdx b/docs/api/qiskit/qiskit.transpiler.TransformationPass.mdx index 07de131e730..bde1bad1fe3 100644 --- a/docs/api/qiskit/qiskit.transpiler.TransformationPass.mdx +++ b/docs/api/qiskit/qiskit.transpiler.TransformationPass.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.TransformationPass # TransformationPass - + Bases: `BasePass` A transformation pass: change DAG, not property set. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.TransformationPass ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.TransformationPass ### name - + Name of the pass. **Return type** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.TransformationPass ### run - + Run a pass on the DAGCircuit. This is implemented by the pass developer. **Parameters** @@ -79,7 +79,7 @@ python_api_name: qiskit.transpiler.TransformationPass ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.TranspileLayout.mdx b/docs/api/qiskit/qiskit.transpiler.TranspileLayout.mdx index e7b03796dcd..be096e4fe3a 100644 --- a/docs/api/qiskit/qiskit.transpiler.TranspileLayout.mdx +++ b/docs/api/qiskit/qiskit.transpiler.TranspileLayout.mdx @@ -8,18 +8,18 @@ python_api_name: qiskit.transpiler.TranspileLayout # TranspileLayout - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") - Layout attributes from output circuit from transpiler. + Layout attributes for the 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. + The [`transpiler`](transpiler#module-qiskit.transpiler "qiskit.transpiler") is unitary-preserving up to the “initial layout” and “final layout” permutations. The initial layout permutation is caused by setting and applying the initial layout during the [Layout Stage](transpiler#layout-stage). The final layout permutation is caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate") insertion during the [Routing Stage](transpiler#routing-stage). This class provides an interface to reason about these permutations using a variety of helper methods. - 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: + During the layout stage, the transpiler can potentially remap the order of the qubits in the circuit as it fits the circuit to the target backend. For example, let the input circuit be: - Then during the layout stage the transpiler reorders the qubits to be: + Suppose that 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: + Then the output of the [`initial_virtual_layout()`](#qiskit.transpiler.TranspileLayout.initial_virtual_layout "qiskit.transpiler.TranspileLayout.initial_virtual_layout") method is equivalent to: ```python Layout({ @@ -29,23 +29,23 @@ python_api_name: qiskit.transpiler.TranspileLayout }) ``` - (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) + (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: + Building on the above example, suppose that during the routing stage the transpiler needs to insert swap gates, and the output circuit becomes: - then the output of the [`routing_permutation()`](#qiskit.transpiler.TranspileLayout.routing_permutation "qiskit.transpiler.TranspileLayout.routing_permutation") method would be: + Then the output of the [`routing_permutation()`](#qiskit.transpiler.TranspileLayout.routing_permutation "qiskit.transpiler.TranspileLayout.routing_permutation") method is: ```python [1, 0, 2] ``` - which maps the qubits at each position to their final position after any swap insertions caused by routing. + which maps positions of qubits before routing to their final positions after 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. + > * [`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 is a [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") object that maps the input [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")s [`Qubit`](circuit#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`](circuit#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 attribute is used to model the permutation caused by the [Routing Stage](transpiler#routing-stage). It is a [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") object that maps the output circuit’s qubits from `QuantumCircuit.qubits` in the output circuit to their final positions after routing. Importantly, this only represents the permutation caused by inserting [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s into the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") during the [Routing Stage](transpiler#routing-stage). 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 [`final_layout`](#qiskit.transpiler.TranspileLayout.final_layout "qiskit.transpiler.TranspileLayout.final_layout") is set to `None`, this indicates that routing was not run, and 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 @@ -65,10 +65,10 @@ python_api_name: qiskit.transpiler.TranspileLayout ### final\_index\_layout - - Generate the final layout as an array of integers + + 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: + This method will generate an array of final positions for each qubit in the input circuit. For example, if you had an input circuit like: ```python qc = QuantumCircuit(3) @@ -81,19 +81,19 @@ python_api_name: qiskit.transpiler.TranspileLayout ```python tqc = QuantumCircuit(3) - qc.h(2) - qc.cx(2, 1) - qc.swap(0, 1) - qc.cx(2, 1) + tqc.h(2) + tqc.cx(2, 1) + tqc.swap(0, 1) + tqc.cx(2, 1) ``` - then the return from this function would be a list of: + then the [`final_index_layout()`](#qiskit.transpiler.TranspileLayout.final_index_layout "qiskit.transpiler.TranspileLayout.final_index_layout") method returns: ```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. + This can be seen as follows. Qubit 0 in the original circuit is mapped to qubit 2 in the output circuit during the layout stage, which is mapped to qubit 2 during the routing stage. Qubit 1 in the original circuit is mapped to qubit 1 in the output circuit during the layout stage, which is mapped to qubit 0 during the routing stage. Qubit 2 in the original circuit is mapped to qubit 0 in the output circuit during the layout stage, which is mapped to qubit 1 during the routing stage. 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** @@ -101,7 +101,7 @@ python_api_name: qiskit.transpiler.TranspileLayout **Returns** - A list of final positions for each input circuit qubit + A list of final positions for each input circuit qubit. **Return type** @@ -110,10 +110,10 @@ python_api_name: qiskit.transpiler.TranspileLayout ### final\_virtual\_layout - - Generate the final layout as a [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") object + + 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: + This method will generate an array of final positions for each qubit in the input circuit. For example, if you had an input circuit like: ```python qc = QuantumCircuit(3) @@ -126,10 +126,10 @@ python_api_name: qiskit.transpiler.TranspileLayout ```python tqc = QuantumCircuit(3) - qc.h(2) - qc.cx(2, 1) - qc.swap(0, 1) - qc.cx(2, 1) + tqc.h(2) + tqc.cx(2, 1) + tqc.swap(0, 1) + tqc.cx(2, 1) ``` then the return from this function would be a layout object: @@ -142,7 +142,7 @@ python_api_name: qiskit.transpiler.TranspileLayout }) ``` - 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. + This can be seen as follows. Qubit 0 in the original circuit is mapped to qubit 2 in the output circuit during the layout stage, which is mapped to qubit 2 during the routing stage. Qubit 1 in the original circuit is mapped to qubit 1 in the output circuit during the layout stage, which is mapped to qubit 0 during the routing stage. Qubit 2 in the original circuit is mapped to qubit 0 in the output circuit during the layout stage, which is mapped to qubit 1 during the routing stage. 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** @@ -150,7 +150,7 @@ python_api_name: qiskit.transpiler.TranspileLayout **Returns** - A layout object mapping to the final positions for each qubit + A layout object mapping to the final positions for each qubit. **Return type** @@ -159,8 +159,8 @@ python_api_name: qiskit.transpiler.TranspileLayout ### initial\_index\_layout - - Generate an initial layout as an array of integers + + Generate an initial layout as an array of integers. **Parameters** @@ -177,10 +177,10 @@ python_api_name: qiskit.transpiler.TranspileLayout ### initial\_virtual\_layout - + 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. + This returns a mapping of virtual [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit") objects in the input circuit to the positions of the physical qubits selected during layout. This is analogous to the [`initial_layout`](#qiskit.transpiler.TranspileLayout.initial_layout "qiskit.transpiler.TranspileLayout.initial_layout") attribute. **Parameters** @@ -188,7 +188,7 @@ python_api_name: qiskit.transpiler.TranspileLayout **Returns** - A layout object mapping the input circuit’s [`Qubit`](qiskit.circuit.Qubit "qiskit.circuit.Qubit") objects to the selected physical qubits. + A layout object mapping the input circuit’s [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit") objects to the positions of the selected physical qubits. **Return type** @@ -197,14 +197,14 @@ python_api_name: qiskit.transpiler.TranspileLayout ### routing\_permutation - - Generate a final layout as an array of integers + + 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 + 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]`. **Returns** - A layout array that maps a position in the array to its new position in the output circuit + A layout array that maps a position in the array to its new position in the output circuit. **Return type** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.ALAPSchedule.mdx b/docs/api/qiskit/qiskit.transpiler.passes.ALAPSchedule.mdx index e69e0cb6305..b9ab449c24f 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.ALAPSchedule.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.ALAPSchedule.mdx @@ -8,15 +8,15 @@ python_api_name: qiskit.transpiler.passes.ALAPSchedule # ALAPSchedule - + 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. + + The class `qiskit.transpiler.passes.scheduling.alap.ALAPSchedule` is deprecated as of qiskit 1.1.0. It will be 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 @@ -45,7 +45,7 @@ python_api_name: qiskit.transpiler.passes.ALAPSchedule ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.ALAPSchedule ### name - + Name of the pass. **Return type** @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.ALAPSchedule ### run - + Run the ALAPSchedule pass on dag. **Parameters** @@ -98,7 +98,7 @@ python_api_name: qiskit.transpiler.passes.ALAPSchedule ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.ALAPScheduleAnalysis.mdx b/docs/api/qiskit/qiskit.transpiler.passes.ALAPScheduleAnalysis.mdx index 8f1dfa18633..9e66c4bab82 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.ALAPScheduleAnalysis.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.ALAPScheduleAnalysis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ALAPScheduleAnalysis # ALAPScheduleAnalysis - + Bases: `BaseScheduler` ALAP Scheduling pass, which schedules the **stop** time of instructions as late as possible. @@ -48,7 +48,7 @@ python_api_name: qiskit.transpiler.passes.ALAPScheduleAnalysis ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -68,7 +68,7 @@ python_api_name: qiskit.transpiler.passes.ALAPScheduleAnalysis ### name - + Name of the pass. **Return type** @@ -78,7 +78,7 @@ python_api_name: qiskit.transpiler.passes.ALAPScheduleAnalysis ### run - + Run the ALAPSchedule pass on dag. **Parameters** @@ -101,7 +101,7 @@ python_api_name: qiskit.transpiler.passes.ALAPScheduleAnalysis ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.ASAPSchedule.mdx b/docs/api/qiskit/qiskit.transpiler.passes.ASAPSchedule.mdx index d4b8ef8d5b0..cc29aa14081 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.ASAPSchedule.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.ASAPSchedule.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ASAPSchedule # ASAPSchedule - + Bases: `BaseSchedulerTransform` ASAP Scheduling pass, which schedules the start time of instructions as early as possible.. @@ -19,8 +19,8 @@ python_api_name: qiskit.transpiler.passes.ASAPSchedule 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. + + The class `qiskit.transpiler.passes.scheduling.asap.ASAPSchedule` is deprecated as of qiskit 1.1.0. It will be 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 @@ -49,7 +49,7 @@ python_api_name: qiskit.transpiler.passes.ASAPSchedule ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.ASAPSchedule ### name - + Name of the pass. **Return type** @@ -79,7 +79,7 @@ python_api_name: qiskit.transpiler.passes.ASAPSchedule ### run - + Run the ASAPSchedule pass on dag. **Parameters** @@ -102,7 +102,7 @@ python_api_name: qiskit.transpiler.passes.ASAPSchedule ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.ASAPScheduleAnalysis.mdx b/docs/api/qiskit/qiskit.transpiler.passes.ASAPScheduleAnalysis.mdx index fa8a1988327..e1c5fc97db3 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.ASAPScheduleAnalysis.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.ASAPScheduleAnalysis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ASAPScheduleAnalysis # ASAPScheduleAnalysis - + Bases: `BaseScheduler` ASAP Scheduling pass, which schedules the start time of instructions as early as possible. @@ -48,7 +48,7 @@ python_api_name: qiskit.transpiler.passes.ASAPScheduleAnalysis ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -68,7 +68,7 @@ python_api_name: qiskit.transpiler.passes.ASAPScheduleAnalysis ### name - + Name of the pass. **Return type** @@ -78,7 +78,7 @@ python_api_name: qiskit.transpiler.passes.ASAPScheduleAnalysis ### run - + Run the ASAPSchedule pass on dag. **Parameters** @@ -101,7 +101,7 @@ python_api_name: qiskit.transpiler.passes.ASAPScheduleAnalysis ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.AlignMeasures.mdx b/docs/api/qiskit/qiskit.transpiler.passes.AlignMeasures.mdx index 6e6190ed190..b57d1ceccae 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.AlignMeasures.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.AlignMeasures.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.AlignMeasures # AlignMeasures - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Measurement alignment. @@ -53,8 +53,8 @@ python_api_name: qiskit.transpiler.passes.AlignMeasures 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. + + The class `qiskit.transpiler.passes.scheduling.alignments.align_measures.AlignMeasures` is deprecated as of qiskit 1.1.0. It will be 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** @@ -83,7 +83,7 @@ python_api_name: qiskit.transpiler.passes.AlignMeasures ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -103,7 +103,7 @@ python_api_name: qiskit.transpiler.passes.AlignMeasures ### name - + Name of the pass. **Return type** @@ -113,7 +113,7 @@ python_api_name: qiskit.transpiler.passes.AlignMeasures ### run - + Run the measurement alignment pass on dag. **Parameters** @@ -135,7 +135,7 @@ python_api_name: qiskit.transpiler.passes.AlignMeasures ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.ApplyLayout.mdx b/docs/api/qiskit/qiskit.transpiler.passes.ApplyLayout.mdx index bb91247db8a..cbe3631b35e 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.ApplyLayout.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.ApplyLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ApplyLayout # ApplyLayout - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Transform a circuit with virtual qubits into a circuit with physical qubits. @@ -39,7 +39,7 @@ python_api_name: qiskit.transpiler.passes.ApplyLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -59,7 +59,7 @@ python_api_name: qiskit.transpiler.passes.ApplyLayout ### name - + Name of the pass. **Return type** @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.ApplyLayout ### run - + Run the ApplyLayout pass on `dag`. **Parameters** @@ -91,7 +91,7 @@ python_api_name: qiskit.transpiler.passes.ApplyLayout ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.mdx b/docs/api/qiskit/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.mdx index 511240b80e5..0df1aa7c530 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.BarrierBeforeFinalMeasurements # BarrierBeforeFinalMeasurements - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Add a barrier before final measurements. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.BarrierBeforeFinalMeasurements ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.BarrierBeforeFinalMeasurements ### name - + Name of the pass. **Return type** @@ -67,13 +67,13 @@ python_api_name: qiskit.transpiler.passes.BarrierBeforeFinalMeasurements ### run - + Run the BarrierBeforeFinalMeasurements pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.BasicSwap.mdx b/docs/api/qiskit/qiskit.transpiler.passes.BasicSwap.mdx index 343b79a4f7d..f273d163f87 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.BasicSwap.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.BasicSwap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.BasicSwap # BasicSwap - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Map (with minimum effort) a DAGCircuit onto a `coupling_map` adding swap gates. @@ -44,7 +44,7 @@ python_api_name: qiskit.transpiler.passes.BasicSwap ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -64,7 +64,7 @@ python_api_name: qiskit.transpiler.passes.BasicSwap ### name - + Name of the pass. **Return type** @@ -74,7 +74,7 @@ python_api_name: qiskit.transpiler.passes.BasicSwap ### run - + Run the BasicSwap pass on dag. **Parameters** @@ -97,7 +97,7 @@ python_api_name: qiskit.transpiler.passes.BasicSwap ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.BasisTranslator.mdx b/docs/api/qiskit/qiskit.transpiler.passes.BasisTranslator.mdx index 9e83cb65946..692aa235dfe 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.BasisTranslator.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.BasisTranslator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.BasisTranslator # BasisTranslator - + 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. @@ -32,7 +32,7 @@ python_api_name: qiskit.transpiler.passes.BasisTranslator 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. + When this error occurs it typically means that either the target basis is not universal or there are additional equivalence rules needed in the [`EquivalenceLibrary`](qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary") instance being used by the [`BasisTranslator`](#qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator") pass. You can refer to [Custom Basis Gates](providers#custom-basis-gates) for details on adding custom equivalence rules. Initialize a BasisTranslator instance. @@ -90,7 +90,7 @@ python_api_name: qiskit.transpiler.passes.BasisTranslator ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -110,7 +110,7 @@ python_api_name: qiskit.transpiler.passes.BasisTranslator ### name - + Name of the pass. **Return type** @@ -120,7 +120,7 @@ python_api_name: qiskit.transpiler.passes.BasisTranslator ### run - + Translate an input DAGCircuit to the target basis. **Parameters** @@ -142,7 +142,7 @@ python_api_name: qiskit.transpiler.passes.BasisTranslator ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.CSPLayout.mdx b/docs/api/qiskit/qiskit.transpiler.passes.CSPLayout.mdx index 51f0391a82b..48efc27f5cb 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.CSPLayout.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.CSPLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CSPLayout # CSPLayout - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") If possible, chooses a Layout as a CSP, using backtracking. @@ -52,7 +52,7 @@ python_api_name: qiskit.transpiler.passes.CSPLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -72,7 +72,7 @@ python_api_name: qiskit.transpiler.passes.CSPLayout ### name - + Name of the pass. **Return type** @@ -82,13 +82,13 @@ python_api_name: qiskit.transpiler.passes.CSPLayout ### run - + run the layout method ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.CXCancellation.mdx b/docs/api/qiskit/qiskit.transpiler.passes.CXCancellation.mdx index 60d127945d6..62932d98a6c 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.CXCancellation.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.CXCancellation.mdx @@ -8,11 +8,15 @@ python_api_name: qiskit.transpiler.passes.CXCancellation # CXCancellation - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Cancel back-to-back `cx` gates in dag. + + The class `qiskit.transpiler.passes.optimization.cx_cancellation.CXCancellation` is deprecated as of qiskit 1.1.0. It will be removed no earlier than 3 months after the release date. Instead, use [`InverseCancellation`](qiskit.transpiler.passes.InverseCancellation "qiskit.transpiler.passes.InverseCancellation"), which is a more generic pass. + + ## Attributes ### is\_analysis\_pass @@ -35,7 +39,7 @@ python_api_name: qiskit.transpiler.passes.CXCancellation ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +59,7 @@ python_api_name: qiskit.transpiler.passes.CXCancellation ### name - + Name of the pass. **Return type** @@ -65,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.CXCancellation ### run - + Run the CXCancellation pass on dag. **Parameters** @@ -83,7 +87,7 @@ python_api_name: qiskit.transpiler.passes.CXCancellation ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.CheckGateDirection.mdx b/docs/api/qiskit/qiskit.transpiler.passes.CheckGateDirection.mdx index 6cf9396f287..d9a376a7c79 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.CheckGateDirection.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.CheckGateDirection.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CheckGateDirection # CheckGateDirection - + 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. @@ -42,7 +42,7 @@ python_api_name: qiskit.transpiler.passes.CheckGateDirection ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -62,7 +62,7 @@ python_api_name: qiskit.transpiler.passes.CheckGateDirection ### name - + Name of the pass. **Return type** @@ -72,7 +72,7 @@ python_api_name: qiskit.transpiler.passes.CheckGateDirection ### run - + 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). @@ -84,7 +84,7 @@ python_api_name: qiskit.transpiler.passes.CheckGateDirection ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.CheckMap.mdx b/docs/api/qiskit/qiskit.transpiler.passes.CheckMap.mdx index ebf2d74f8a9..66529134aa5 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.CheckMap.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.CheckMap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CheckMap # CheckMap - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Check if a DAG circuit is already mapped to a coupling map. @@ -44,7 +44,7 @@ python_api_name: qiskit.transpiler.passes.CheckMap ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -64,7 +64,7 @@ python_api_name: qiskit.transpiler.passes.CheckMap ### name - + Name of the pass. **Return type** @@ -74,7 +74,7 @@ python_api_name: qiskit.transpiler.passes.CheckMap ### run - + 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). @@ -86,7 +86,7 @@ python_api_name: qiskit.transpiler.passes.CheckMap ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.Collect1qRuns.mdx b/docs/api/qiskit/qiskit.transpiler.passes.Collect1qRuns.mdx index 65a1c218af3..1389a25035e 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.Collect1qRuns.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.Collect1qRuns.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Collect1qRuns # Collect1qRuns - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Collect one-qubit subcircuits. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.passes.Collect1qRuns ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.Collect1qRuns ### name - + Name of the pass. **Return type** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.Collect1qRuns ### run - + 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. @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.Collect1qRuns ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.Collect2qBlocks.mdx b/docs/api/qiskit/qiskit.transpiler.passes.Collect2qBlocks.mdx index 75f22fa43dc..f366f7fc813 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.Collect2qBlocks.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.Collect2qBlocks.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Collect2qBlocks # Collect2qBlocks - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Collect two-qubit subcircuits. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.passes.Collect2qBlocks ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.Collect2qBlocks ### name - + Name of the pass. **Return type** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.Collect2qBlocks ### run - + 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. @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.Collect2qBlocks ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.CollectCliffords.mdx b/docs/api/qiskit/qiskit.transpiler.passes.CollectCliffords.mdx index b2554946253..fdf5d92cae2 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.CollectCliffords.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.CollectCliffords.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CollectCliffords # CollectCliffords - + Bases: `CollectAndCollapse` Collects blocks of Clifford gates and replaces them by a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") object. @@ -45,7 +45,7 @@ python_api_name: qiskit.transpiler.passes.CollectCliffords ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.CollectCliffords ### name - + Name of the pass. **Return type** @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.CollectCliffords ### run - + Run the CollectLinearFunctions pass on dag. :param dag: the DAG to be optimized. :type dag: DAGCircuit **Returns** @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.CollectCliffords ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.CollectLinearFunctions.mdx b/docs/api/qiskit/qiskit.transpiler.passes.CollectLinearFunctions.mdx index 0a4320cc660..7113f8eb806 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.CollectLinearFunctions.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.CollectLinearFunctions.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CollectLinearFunctions # CollectLinearFunctions - + 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")). @@ -45,7 +45,7 @@ python_api_name: qiskit.transpiler.passes.CollectLinearFunctions ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.CollectLinearFunctions ### name - + Name of the pass. **Return type** @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.CollectLinearFunctions ### run - + Run the CollectLinearFunctions pass on dag. :param dag: the DAG to be optimized. :type dag: DAGCircuit **Returns** @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.CollectLinearFunctions ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.CollectMultiQBlocks.mdx b/docs/api/qiskit/qiskit.transpiler.passes.CollectMultiQBlocks.mdx index 0efb01d4b23..b9fe3ce77e5 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.CollectMultiQBlocks.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.CollectMultiQBlocks.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CollectMultiQBlocks # CollectMultiQBlocks - + 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 @@ -45,7 +45,7 @@ python_api_name: qiskit.transpiler.passes.CollectMultiQBlocks ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -65,13 +65,13 @@ python_api_name: qiskit.transpiler.passes.CollectMultiQBlocks ### find\_set - + 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 of the pass. **Return type** @@ -81,7 +81,7 @@ python_api_name: qiskit.transpiler.passes.CollectMultiQBlocks ### run - + 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. @@ -93,13 +93,13 @@ python_api_name: qiskit.transpiler.passes.CollectMultiQBlocks ### union\_set - + 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 workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.CommutationAnalysis.mdx b/docs/api/qiskit/qiskit.transpiler.passes.CommutationAnalysis.mdx index 2dd8fa3b0af..078a686b2d8 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.CommutationAnalysis.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.CommutationAnalysis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CommutationAnalysis # CommutationAnalysis - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Analysis pass to find commutation relations between DAG nodes. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.CommutationAnalysis ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.CommutationAnalysis ### name - + Name of the pass. **Return type** @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.CommutationAnalysis ### run - + Run the CommutationAnalysis pass on dag. Run the pass on the DAG, and write the discovered commutation relations into the `property_set`. @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.CommutationAnalysis ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.CommutativeCancellation.mdx b/docs/api/qiskit/qiskit.transpiler.passes.CommutativeCancellation.mdx index 5902cc4c4ea..1065f594b98 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.CommutativeCancellation.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.CommutativeCancellation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeCancellation # CommutativeCancellation - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Cancel the redundant (self-adjoint) gates through commutation relations. @@ -48,7 +48,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeCancellation ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -68,7 +68,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeCancellation ### name - + Name of the pass. **Return type** @@ -78,7 +78,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeCancellation ### run - + Run the CommutativeCancellation pass on dag. **Parameters** @@ -100,7 +100,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeCancellation ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.CommutativeInverseCancellation.mdx b/docs/api/qiskit/qiskit.transpiler.passes.CommutativeInverseCancellation.mdx index cea8f2d4ca7..cc9ba5f4a2c 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.CommutativeInverseCancellation.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.CommutativeInverseCancellation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeInverseCancellation # CommutativeInverseCancellation - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Cancel pairs of inverse gates exploiting commutation relations. @@ -40,7 +40,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeInverseCancellation ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -60,7 +60,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeInverseCancellation ### name - + Name of the pass. **Return type** @@ -70,7 +70,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeInverseCancellation ### run - + Run the CommutativeInverseCancellation pass on dag. **Parameters** @@ -88,7 +88,7 @@ python_api_name: qiskit.transpiler.passes.CommutativeInverseCancellation ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.Commuting2qGateRouter.mdx b/docs/api/qiskit/qiskit.transpiler.passes.Commuting2qGateRouter.mdx index b8234b267ac..495e34e51d8 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.Commuting2qGateRouter.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.Commuting2qGateRouter.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Commuting2qGateRouter # Commuting2qGateRouter - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") A class to swap route one or more commuting gates to the coupling map. @@ -97,7 +97,7 @@ python_api_name: qiskit.transpiler.passes.Commuting2qGateRouter ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -117,7 +117,7 @@ python_api_name: qiskit.transpiler.passes.Commuting2qGateRouter ### name - + Name of the pass. **Return type** @@ -127,7 +127,7 @@ python_api_name: qiskit.transpiler.passes.Commuting2qGateRouter ### run - + Run the pass by decomposing the nodes it applies on. **Parameters** @@ -151,7 +151,7 @@ python_api_name: qiskit.transpiler.passes.Commuting2qGateRouter ### swap\_decompose - + Take an instance of `Commuting2qBlock` and map it to the coupling map. The mapping is done with the swap strategy. @@ -174,7 +174,7 @@ python_api_name: qiskit.transpiler.passes.Commuting2qGateRouter ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.ConsolidateBlocks.mdx b/docs/api/qiskit/qiskit.transpiler.passes.ConsolidateBlocks.mdx index b63134c63f5..94a24d4962c 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.ConsolidateBlocks.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.ConsolidateBlocks.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ConsolidateBlocks # ConsolidateBlocks - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Replace each block of consecutive gates by a single Unitary node. @@ -53,7 +53,7 @@ python_api_name: qiskit.transpiler.passes.ConsolidateBlocks ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -73,7 +73,7 @@ python_api_name: qiskit.transpiler.passes.ConsolidateBlocks ### name - + Name of the pass. **Return type** @@ -83,7 +83,7 @@ python_api_name: qiskit.transpiler.passes.ConsolidateBlocks ### run - + Run the ConsolidateBlocks pass on dag. Iterate over each block and replace it with an equivalent Unitary on the same wires. @@ -91,7 +91,7 @@ python_api_name: qiskit.transpiler.passes.ConsolidateBlocks ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.ConstrainedReschedule.mdx b/docs/api/qiskit/qiskit.transpiler.passes.ConstrainedReschedule.mdx index ba330d55f73..e8e99668034 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.ConstrainedReschedule.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.ConstrainedReschedule.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ConstrainedReschedule # ConstrainedReschedule - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Rescheduler pass that updates node start times to conform to the hardware alignments. @@ -49,6 +49,7 @@ python_api_name: qiskit.transpiler.passes.ConstrainedReschedule * **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`. + * **target** – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if `target` is specified then this argument will take precedence and `acquire_alignment` and `pulse_alignment` will be ignored. ## Attributes @@ -72,7 +73,7 @@ python_api_name: qiskit.transpiler.passes.ConstrainedReschedule ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -92,7 +93,7 @@ python_api_name: qiskit.transpiler.passes.ConstrainedReschedule ### name - + Name of the pass. **Return type** @@ -102,7 +103,7 @@ python_api_name: qiskit.transpiler.passes.ConstrainedReschedule ### run - + Run rescheduler. This pass should perform rescheduling to satisfy: @@ -145,7 +146,7 @@ python_api_name: qiskit.transpiler.passes.ConstrainedReschedule ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.ContainsInstruction.mdx b/docs/api/qiskit/qiskit.transpiler.passes.ContainsInstruction.mdx index fc9ef297289..1e46c307a49 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.ContainsInstruction.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.ContainsInstruction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ContainsInstruction # ContainsInstruction - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") An analysis pass to detect if the DAG contains a specific instruction. @@ -44,7 +44,7 @@ python_api_name: qiskit.transpiler.passes.ContainsInstruction ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -64,7 +64,7 @@ python_api_name: qiskit.transpiler.passes.ContainsInstruction ### name - + Name of the pass. **Return type** @@ -74,13 +74,13 @@ python_api_name: qiskit.transpiler.passes.ContainsInstruction ### run - + Run the ContainsInstruction pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.ConvertConditionsToIfOps.mdx b/docs/api/qiskit/qiskit.transpiler.passes.ConvertConditionsToIfOps.mdx index c6bda97b6f5..ce803712df1 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.ConvertConditionsToIfOps.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.ConvertConditionsToIfOps.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ConvertConditionsToIfOps # ConvertConditionsToIfOps - + 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`. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.ConvertConditionsToIfOps ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.ConvertConditionsToIfOps ### name - + Name of the pass. **Return type** @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.ConvertConditionsToIfOps ### run - + Run a pass on the DAGCircuit. This is implemented by the pass developer. **Parameters** @@ -81,7 +81,7 @@ python_api_name: qiskit.transpiler.passes.ConvertConditionsToIfOps ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.CountOps.mdx b/docs/api/qiskit/qiskit.transpiler.passes.CountOps.mdx index 70920f1f5c8..dc308c940b7 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.CountOps.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.CountOps.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CountOps # CountOps - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Count the operations in a DAG circuit. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.CountOps ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.CountOps ### name - + Name of the pass. **Return type** @@ -67,13 +67,13 @@ python_api_name: qiskit.transpiler.passes.CountOps ### run - + Run the CountOps pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.CountOpsLongestPath.mdx b/docs/api/qiskit/qiskit.transpiler.passes.CountOpsLongestPath.mdx index 39292c12f35..e917c95d5ce 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.CountOpsLongestPath.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.CountOpsLongestPath.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.CountOpsLongestPath # CountOpsLongestPath - + 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"). @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.CountOpsLongestPath ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.CountOpsLongestPath ### name - + Name of the pass. **Return type** @@ -67,13 +67,13 @@ python_api_name: qiskit.transpiler.passes.CountOpsLongestPath ### run - + Run the CountOpsLongestPath pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.DAGFixedPoint.mdx b/docs/api/qiskit/qiskit.transpiler.passes.DAGFixedPoint.mdx index ad27701002e..60b6b9aee6c 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.DAGFixedPoint.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.DAGFixedPoint.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.DAGFixedPoint # DAGFixedPoint - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Check if the DAG has reached a fixed point. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.DAGFixedPoint ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.DAGFixedPoint ### name - + Name of the pass. **Return type** @@ -67,13 +67,13 @@ python_api_name: qiskit.transpiler.passes.DAGFixedPoint ### run - + Run the DAGFixedPoint pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.DAGLongestPath.mdx b/docs/api/qiskit/qiskit.transpiler.passes.DAGLongestPath.mdx index 74348235480..b51eb0caa25 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.DAGLongestPath.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.DAGLongestPath.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.DAGLongestPath # DAGLongestPath - + 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. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.passes.DAGLongestPath ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.DAGLongestPath ### name - + Name of the pass. **Return type** @@ -65,13 +65,13 @@ python_api_name: qiskit.transpiler.passes.DAGLongestPath ### run - + Run the DAGLongestPath pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.Decompose.mdx b/docs/api/qiskit/qiskit.transpiler.passes.Decompose.mdx index b9e5697c001..82d3eba005e 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.Decompose.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.Decompose.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Decompose # Decompose - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Expand a gate in a circuit using its decomposition rules. @@ -41,7 +41,7 @@ python_api_name: qiskit.transpiler.passes.Decompose ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -61,7 +61,7 @@ python_api_name: qiskit.transpiler.passes.Decompose ### name - + Name of the pass. **Return type** @@ -71,7 +71,7 @@ python_api_name: qiskit.transpiler.passes.Decompose ### run - + Run the Decompose pass on dag. **Parameters** @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.Decompose ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.DenseLayout.mdx b/docs/api/qiskit/qiskit.transpiler.passes.DenseLayout.mdx index 3d8eb7742dd..e5d4e4c23da 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.DenseLayout.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.DenseLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.DenseLayout # DenseLayout - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Choose a Layout by finding the most connected subset of qubits. @@ -49,7 +49,7 @@ python_api_name: qiskit.transpiler.passes.DenseLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.DenseLayout ### name - + Name of the pass. **Return type** @@ -79,7 +79,7 @@ python_api_name: qiskit.transpiler.passes.DenseLayout ### run - + Run the DenseLayout pass on dag. Pick a convenient layout depending on the best matching qubit connectivity, and set the property layout. @@ -95,7 +95,7 @@ python_api_name: qiskit.transpiler.passes.DenseLayout ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.Depth.mdx b/docs/api/qiskit/qiskit.transpiler.passes.Depth.mdx index c514736f0cc..23bbaad8454 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.Depth.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.Depth.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Depth # Depth - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Calculate the depth of a DAG circuit. @@ -39,7 +39,7 @@ python_api_name: qiskit.transpiler.passes.Depth ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -59,7 +59,7 @@ python_api_name: qiskit.transpiler.passes.Depth ### name - + Name of the pass. **Return type** @@ -69,13 +69,13 @@ python_api_name: qiskit.transpiler.passes.Depth ### run - + Run the Depth pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.DynamicalDecoupling.mdx b/docs/api/qiskit/qiskit.transpiler.passes.DynamicalDecoupling.mdx index 4d9be51aa10..f33d423dc64 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.DynamicalDecoupling.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.DynamicalDecoupling.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.DynamicalDecoupling # DynamicalDecoupling - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Dynamical decoupling insertion pass. @@ -83,8 +83,8 @@ python_api_name: qiskit.transpiler.passes.DynamicalDecoupling 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. + + The class `qiskit.transpiler.passes.scheduling.dynamical_decoupling.DynamicalDecoupling` is deprecated as of qiskit 1.1.0. It will be 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** @@ -118,7 +118,7 @@ python_api_name: qiskit.transpiler.passes.DynamicalDecoupling ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -138,7 +138,7 @@ python_api_name: qiskit.transpiler.passes.DynamicalDecoupling ### name - + Name of the pass. **Return type** @@ -148,7 +148,7 @@ python_api_name: qiskit.transpiler.passes.DynamicalDecoupling ### run - + Run the DynamicalDecoupling pass on dag. **Parameters** @@ -172,7 +172,7 @@ python_api_name: qiskit.transpiler.passes.DynamicalDecoupling ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.EchoRZXWeylDecomposition.mdx b/docs/api/qiskit/qiskit.transpiler.passes.EchoRZXWeylDecomposition.mdx index e1198855e45..63056d2f34f 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.EchoRZXWeylDecomposition.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.EchoRZXWeylDecomposition.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.EchoRZXWeylDecomposition # EchoRZXWeylDecomposition - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Rewrite two-qubit gates using the Weyl decomposition. @@ -44,7 +44,7 @@ python_api_name: qiskit.transpiler.passes.EchoRZXWeylDecomposition ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -64,7 +64,7 @@ python_api_name: qiskit.transpiler.passes.EchoRZXWeylDecomposition ### name - + Name of the pass. **Return type** @@ -74,7 +74,7 @@ python_api_name: qiskit.transpiler.passes.EchoRZXWeylDecomposition ### run - + 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. @@ -98,7 +98,7 @@ python_api_name: qiskit.transpiler.passes.EchoRZXWeylDecomposition ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.ElidePermutations.mdx b/docs/api/qiskit/qiskit.transpiler.passes.ElidePermutations.mdx new file mode 100644 index 00000000000..45aa434fe38 --- /dev/null +++ b/docs/api/qiskit/qiskit.transpiler.passes.ElidePermutations.mdx @@ -0,0 +1,119 @@ +--- +title: ElidePermutations +description: API reference for qiskit.transpiler.passes.ElidePermutations +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.ElidePermutations +--- + +# ElidePermutations + + + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + + Remove permutation operations from a pre-layout circuit + + This pass is intended to be run before a layout (mapping virtual qubits to physical qubits) is set during the transpilation pipeline. This pass iterates over the [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") and when a [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate") or [`PermutationGate`](qiskit.circuit.library.PermutationGate "qiskit.circuit.library.PermutationGate") are encountered it permutes the virtual qubits in the circuit and removes the swap gate. This will effectively remove any `SwapGate`s or `PermutationGate` in the circuit prior to running layout. If this pass is run after a layout has been set it will become a no-op (and log a warning) as this optimization is not sound after physical qubits are selected and there are connectivity constraints to adhere to. + + For tracking purposes this pass sets 3 values in the property set if there are any [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate") or [`PermutationGate`](qiskit.circuit.library.PermutationGate "qiskit.circuit.library.PermutationGate") objects in the circuit and the pass isn’t a no-op. + + * `original_layout`: The trivial [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") for the input to this pass being run + + * **`original_qubit_indices`: The mapping of qubit objects to positional indices for the state** + + of the circuit as input to this pass. + + * **`virtual_permutation_layout`: A [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") object mapping input qubits to the output** + + state after eliding permutations. + + These three properties are needed for the transpiler to track the permutations in the out [`QuantumCircuit.layout`](qiskit.circuit.QuantumCircuit#layout "qiskit.circuit.QuantumCircuit.layout") attribute. The elision of permutations is equivalent to a `final_layout` set by routing and all three of these attributes are needed in the case + + ## 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the ElidePermutations 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 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/qiskit.transpiler.passes.EnlargeWithAncilla.mdx b/docs/api/qiskit/qiskit.transpiler.passes.EnlargeWithAncilla.mdx index 9c543a3ef81..efdb8d8a926 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.EnlargeWithAncilla.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.EnlargeWithAncilla.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.EnlargeWithAncilla # EnlargeWithAncilla - + 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. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.EnlargeWithAncilla ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.EnlargeWithAncilla ### name - + Name of the pass. **Return type** @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.EnlargeWithAncilla ### run - + Run the EnlargeWithAncilla pass on dag. **Parameters** @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.EnlargeWithAncilla ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.FilterOpNodes.mdx b/docs/api/qiskit/qiskit.transpiler.passes.FilterOpNodes.mdx index e0978169678..adb68138fb0 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.FilterOpNodes.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.FilterOpNodes.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.FilterOpNodes # FilterOpNodes - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Remove all operations that match a filter function @@ -62,7 +62,7 @@ python_api_name: qiskit.transpiler.passes.FilterOpNodes ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -82,7 +82,7 @@ python_api_name: qiskit.transpiler.passes.FilterOpNodes ### name - + Name of the pass. **Return type** @@ -92,7 +92,7 @@ python_api_name: qiskit.transpiler.passes.FilterOpNodes ### run - + Run the RemoveBarriers pass on dag. **Return type** @@ -102,7 +102,7 @@ python_api_name: qiskit.transpiler.passes.FilterOpNodes ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.FixedPoint.mdx b/docs/api/qiskit/qiskit.transpiler.passes.FixedPoint.mdx index 0bb11d9f0f1..9a27d56ee72 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.FixedPoint.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.FixedPoint.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.FixedPoint # FixedPoint - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Check if a property reached a fixed point. @@ -43,7 +43,7 @@ python_api_name: qiskit.transpiler.passes.FixedPoint ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -63,7 +63,7 @@ python_api_name: qiskit.transpiler.passes.FixedPoint ### name - + Name of the pass. **Return type** @@ -73,13 +73,13 @@ python_api_name: qiskit.transpiler.passes.FixedPoint ### run - + Run the FixedPoint pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.FullAncillaAllocation.mdx b/docs/api/qiskit/qiskit.transpiler.passes.FullAncillaAllocation.mdx index 98fcb0cb9af..5000ddbba61 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.FullAncillaAllocation.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.FullAncillaAllocation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.FullAncillaAllocation # FullAncillaAllocation - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Allocate all idle nodes from the coupling map or target as ancilla on the layout. @@ -47,7 +47,7 @@ python_api_name: qiskit.transpiler.passes.FullAncillaAllocation ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.FullAncillaAllocation ### name - + Name of the pass. **Return type** @@ -77,7 +77,7 @@ python_api_name: qiskit.transpiler.passes.FullAncillaAllocation ### run - + 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) @@ -103,7 +103,7 @@ python_api_name: qiskit.transpiler.passes.FullAncillaAllocation ### update\_status - + Update workflow status. **Parameters** @@ -122,7 +122,7 @@ python_api_name: qiskit.transpiler.passes.FullAncillaAllocation ### validate\_layout - + Checks if all the qregs in `layout_qregs` already exist in `dag_qregs`. Otherwise, raise. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.GateDirection.mdx b/docs/api/qiskit/qiskit.transpiler.passes.GateDirection.mdx index 5fd8b0662ce..a7b0bcdb3f4 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.GateDirection.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.GateDirection.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.GateDirection # GateDirection - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Modify asymmetric gates to match the hardware coupling direction. @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.GateDirection ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.GateDirection ### name - + Name of the pass. **Return type** @@ -99,7 +99,7 @@ python_api_name: qiskit.transpiler.passes.GateDirection ### run - + Run the GateDirection pass on dag. Flips the cx nodes to match the directed coupling map. Modifies the input dag. @@ -123,7 +123,7 @@ python_api_name: qiskit.transpiler.passes.GateDirection ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.GatesInBasis.mdx b/docs/api/qiskit/qiskit.transpiler.passes.GatesInBasis.mdx index 460797ad597..3d3ddc236fa 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.GatesInBasis.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.GatesInBasis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.GatesInBasis # GatesInBasis - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Check if all gates in a DAG are in a given set of gates @@ -42,7 +42,7 @@ python_api_name: qiskit.transpiler.passes.GatesInBasis ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -62,7 +62,7 @@ python_api_name: qiskit.transpiler.passes.GatesInBasis ### name - + Name of the pass. **Return type** @@ -72,13 +72,13 @@ python_api_name: qiskit.transpiler.passes.GatesInBasis ### run - + Run the GatesInBasis pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.HLSConfig.mdx b/docs/api/qiskit/qiskit.transpiler.passes.HLSConfig.mdx index 45b076d649d..14b20c1332a 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.HLSConfig.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.HLSConfig.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.HLSConfig # HLSConfig - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") The high-level-synthesis config allows to specify a list of “methods” used by [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis") transformation pass to synthesize different types of higher-level objects. @@ -50,13 +50,15 @@ python_api_name: qiskit.transpiler.passes.HLSConfig **Parameters** * **use\_default\_on\_unspecified** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, every higher-level-object without an explicitly specified list of methods will be synthesized using the “default” algorithm if it exists. + * **plugin\_selection** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – if set to `"sequential"` (default), for every higher-level-object the synthesis pass will consider the specified methods sequentially, stopping at the first method that is able to synthesize the object. If set to `"all"`, all the specified methods will be considered, and the best synthesized circuit, according to `plugin_evaluation_fn` will be chosen. + * **plugin\_evaluation\_fn** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")*],* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – a callable that evaluates the quality of the synthesized quantum circuit; a smaller value means a better circuit. If `None`, the quality of the circuit its size (i.e. the number of gates that it contains). * **kwargs** – a dictionary mapping higher-level-objects to lists of synthesis methods. ## Methods ### set\_methods - + Sets the list of synthesis methods for a given higher-level-object. This overwrites the lists of methods if also set previously. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.HighLevelSynthesis.mdx b/docs/api/qiskit/qiskit.transpiler.passes.HighLevelSynthesis.mdx index 8f9106b6d84..db37fdcfaff 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.HighLevelSynthesis.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.HighLevelSynthesis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.HighLevelSynthesis # HighLevelSynthesis - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Synthesize higher-level objects and unroll custom definitions. @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.HighLevelSynthesis ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.HighLevelSynthesis ### name - + Name of the pass. **Return type** @@ -99,7 +99,7 @@ python_api_name: qiskit.transpiler.passes.HighLevelSynthesis ### run - + Run the HighLevelSynthesis pass on dag. **Parameters** @@ -122,7 +122,7 @@ python_api_name: qiskit.transpiler.passes.HighLevelSynthesis ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.HoareOptimizer.mdx b/docs/api/qiskit/qiskit.transpiler.passes.HoareOptimizer.mdx index 6f272bceac7..85ab18ddb4b 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.HoareOptimizer.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.HoareOptimizer.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.HoareOptimizer # HoareOptimizer - + 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) @@ -43,7 +43,7 @@ python_api_name: qiskit.transpiler.passes.HoareOptimizer ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -63,7 +63,7 @@ python_api_name: qiskit.transpiler.passes.HoareOptimizer ### name - + Name of the pass. **Return type** @@ -73,7 +73,7 @@ python_api_name: qiskit.transpiler.passes.HoareOptimizer ### run - + **Parameters** **dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the directed acyclic graph to run on. @@ -89,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.HoareOptimizer ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.InstructionDurationCheck.mdx b/docs/api/qiskit/qiskit.transpiler.passes.InstructionDurationCheck.mdx index 7d4aeb6d379..865aabf7b0c 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.InstructionDurationCheck.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.InstructionDurationCheck.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.InstructionDurationCheck # InstructionDurationCheck - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Duration validation pass for reschedule. @@ -25,6 +25,7 @@ python_api_name: qiskit.transpiler.passes.InstructionDurationCheck * **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`. + * **target** – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if `target` is specified then this argument will take precedence and `acquire_alignment` and `pulse_alignment` will be ignored. ## Attributes @@ -48,7 +49,7 @@ python_api_name: qiskit.transpiler.passes.InstructionDurationCheck ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -68,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.InstructionDurationCheck ### name - + Name of the pass. **Return type** @@ -78,7 +79,7 @@ python_api_name: qiskit.transpiler.passes.InstructionDurationCheck ### run - + Run duration validation passes. **Parameters** @@ -88,7 +89,7 @@ python_api_name: qiskit.transpiler.passes.InstructionDurationCheck ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.InverseCancellation.mdx b/docs/api/qiskit/qiskit.transpiler.passes.InverseCancellation.mdx index ae58fbb7f5b..a1505b85725 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.InverseCancellation.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.InverseCancellation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.InverseCancellation # InverseCancellation - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Cancel specific Gates which are inverses of each other when they occur back-to- back. @@ -45,7 +45,7 @@ python_api_name: qiskit.transpiler.passes.InverseCancellation ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.InverseCancellation ### name - + Name of the pass. **Return type** @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.InverseCancellation ### run - + Run the InverseCancellation pass on dag. **Parameters** @@ -93,7 +93,7 @@ python_api_name: qiskit.transpiler.passes.InverseCancellation ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.Layout2qDistance.mdx b/docs/api/qiskit/qiskit.transpiler.passes.Layout2qDistance.mdx index ea937d76a85..d528dd9cac6 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.Layout2qDistance.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.Layout2qDistance.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Layout2qDistance # Layout2qDistance - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Evaluate how good the layout selection was. @@ -44,7 +44,7 @@ python_api_name: qiskit.transpiler.passes.Layout2qDistance ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -64,7 +64,7 @@ python_api_name: qiskit.transpiler.passes.Layout2qDistance ### name - + Name of the pass. **Return type** @@ -74,13 +74,13 @@ python_api_name: qiskit.transpiler.passes.Layout2qDistance ### run - + Run the Layout2qDistance pass on dag. :param dag: DAG to evaluate. :type dag: DAGCircuit ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.LinearFunctionsToPermutations.mdx b/docs/api/qiskit/qiskit.transpiler.passes.LinearFunctionsToPermutations.mdx index 24cf9ecf8c2..42b37e4d95e 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.LinearFunctionsToPermutations.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.LinearFunctionsToPermutations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.LinearFunctionsToPermutations # LinearFunctionsToPermutations - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Promotes linear functions to permutations when possible. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.passes.LinearFunctionsToPermutations ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.LinearFunctionsToPermutations ### name - + Name of the pass. **Return type** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.LinearFunctionsToPermutations ### run - + Run the LinearFunctionsToPermutations pass on dag. :param dag: input dag. **Returns** @@ -79,7 +79,7 @@ python_api_name: qiskit.transpiler.passes.LinearFunctionsToPermutations ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.LookaheadSwap.mdx b/docs/api/qiskit/qiskit.transpiler.passes.LookaheadSwap.mdx index 7cc5df1e7b6..3f2f4f5a221 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.LookaheadSwap.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.LookaheadSwap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.LookaheadSwap # LookaheadSwap - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Map input circuit onto a backend topology via insertion of SWAPs. @@ -60,7 +60,7 @@ python_api_name: qiskit.transpiler.passes.LookaheadSwap ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -80,7 +80,7 @@ python_api_name: qiskit.transpiler.passes.LookaheadSwap ### name - + Name of the pass. **Return type** @@ -90,7 +90,7 @@ python_api_name: qiskit.transpiler.passes.LookaheadSwap ### run - + Run the LookaheadSwap pass on dag. **Parameters** @@ -115,7 +115,7 @@ python_api_name: qiskit.transpiler.passes.LookaheadSwap ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.MergeAdjacentBarriers.mdx b/docs/api/qiskit/qiskit.transpiler.passes.MergeAdjacentBarriers.mdx index ce2aa8f5ba4..75fc34a4972 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.MergeAdjacentBarriers.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.MergeAdjacentBarriers.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.MergeAdjacentBarriers # MergeAdjacentBarriers - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Return a circuit with any adjacent barriers merged together. @@ -72,7 +72,7 @@ python_api_name: qiskit.transpiler.passes.MergeAdjacentBarriers ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -92,7 +92,7 @@ python_api_name: qiskit.transpiler.passes.MergeAdjacentBarriers ### name - + Name of the pass. **Return type** @@ -102,13 +102,13 @@ python_api_name: qiskit.transpiler.passes.MergeAdjacentBarriers ### run - + Run the MergeAdjacentBarriers pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.MinimumPoint.mdx b/docs/api/qiskit/qiskit.transpiler.passes.MinimumPoint.mdx index a265d5dd8d9..4395180c294 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.MinimumPoint.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.MinimumPoint.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.MinimumPoint # MinimumPoint - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Check if the DAG has reached a relative semi-stable point over previous runs @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.MinimumPoint ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.MinimumPoint ### name - + Name of the pass. **Return type** @@ -85,13 +85,13 @@ python_api_name: qiskit.transpiler.passes.MinimumPoint ### run - + Run the MinimumPoint pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.NormalizeRXAngle.mdx b/docs/api/qiskit/qiskit.transpiler.passes.NormalizeRXAngle.mdx index ecaa7f7d123..610f5319cba 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.NormalizeRXAngle.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.NormalizeRXAngle.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.NormalizeRXAngle # NormalizeRXAngle - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Normalize theta parameter of RXGate instruction. @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.NormalizeRXAngle ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -77,7 +77,7 @@ python_api_name: qiskit.transpiler.passes.NormalizeRXAngle ### name - + Name of the pass. **Return type** @@ -87,12 +87,12 @@ python_api_name: qiskit.transpiler.passes.NormalizeRXAngle ### quantize\_angles - + Quantize the RX rotation angles by assigning the same value for the angles that differ within a resolution provided by the user. **Parameters** - * **qubit** ([*qiskit.circuit.Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")) – This will be the dict key to access the list of quantized rotation angles. + * **qubit** ([*qiskit.circuit.Qubit*](circuit#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** @@ -106,7 +106,7 @@ python_api_name: qiskit.transpiler.passes.NormalizeRXAngle ### run - + Run the NormalizeRXAngle pass on `dag`. **Parameters** @@ -124,7 +124,7 @@ python_api_name: qiskit.transpiler.passes.NormalizeRXAngle ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.NumTensorFactors.mdx b/docs/api/qiskit/qiskit.transpiler.passes.NumTensorFactors.mdx index d1116661d30..16ae65b8d28 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.NumTensorFactors.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.NumTensorFactors.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.NumTensorFactors # NumTensorFactors - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Calculate the number of tensor factors of a DAG circuit. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.NumTensorFactors ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.NumTensorFactors ### name - + Name of the pass. **Return type** @@ -67,13 +67,13 @@ python_api_name: qiskit.transpiler.passes.NumTensorFactors ### run - + Run the NumTensorFactors pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.Optimize1qGates.mdx b/docs/api/qiskit/qiskit.transpiler.passes.Optimize1qGates.mdx index a6d4101191d..1454fbf415b 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.Optimize1qGates.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.Optimize1qGates.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGates # Optimize1qGates - + 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. @@ -43,7 +43,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGates ### compose\_u3 - + Return a triple theta, phi, lambda for the product. **u3(theta, phi, lambda)** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGates ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGates ### name - + Name of the pass. **Return type** @@ -85,7 +85,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGates ### run - + Run the Optimize1qGates pass on dag. **Parameters** @@ -107,7 +107,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGates ### update\_status - + Update workflow status. **Parameters** @@ -126,7 +126,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGates ### yzy\_to\_zyz - + Express a Y.Z.Y single qubit gate as a Z.Y.Z gate. Solve the equation diff --git a/docs/api/qiskit/qiskit.transpiler.passes.Optimize1qGatesDecomposition.mdx b/docs/api/qiskit/qiskit.transpiler.passes.Optimize1qGatesDecomposition.mdx index fe41c71dcfc..ed2c6a521ef 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.Optimize1qGatesDecomposition.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.Optimize1qGatesDecomposition.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesDecomposition # Optimize1qGatesDecomposition - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Optimize chains of single-qubit gates by combining them into a single gate. @@ -51,7 +51,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesDecomposition ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -71,7 +71,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesDecomposition ### name - + Name of the pass. **Return type** @@ -81,7 +81,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesDecomposition ### run - + Run the Optimize1qGatesDecomposition pass on dag. **Parameters** @@ -99,7 +99,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesDecomposition ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.mdx b/docs/api/qiskit/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.mdx index dd3510b26d5..cb8869c8774 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation # Optimize1qGatesSimpleCommutation - + 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`. @@ -47,7 +47,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation ### name - + Name of the pass. **Return type** @@ -77,7 +77,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation ### run - + **Parameters** **dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the DAG to be optimized. @@ -93,7 +93,7 @@ python_api_name: qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.OptimizeAnnotated.mdx b/docs/api/qiskit/qiskit.transpiler.passes.OptimizeAnnotated.mdx index e29d4dabcf5..5a15177682a 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.OptimizeAnnotated.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.OptimizeAnnotated.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeAnnotated # OptimizeAnnotated - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Optimization pass on circuits with annotated operations. @@ -18,6 +18,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeAnnotated * For each annotated operation, converting the list of its modifiers to a canonical form. For example, consecutively applying `inverse()`, `control(2)` and `inverse()` is equivalent to applying `control(2)`. * Removing annotations when possible. For example, `AnnotatedOperation(SwapGate(), [InverseModifier(), InverseModifier()])` is equivalent to `SwapGate()`. * Recursively combining annotations. For example, if `g1 = AnnotatedOperation(SwapGate(), InverseModifier())` and `g2 = AnnotatedOperation(g1, ControlModifier(2))`, then `g2` can be replaced with `AnnotatedOperation(SwapGate(), [InverseModifier(), ControlModifier(2)])`. + * Applies conjugate reduction to annotated operations. As an example, `control - [P -- Q -- P^{-1}]` can be rewritten as `P -- control - [Q] -- P^{-1}`, that is, only the middle part needs to be controlled. This also works for inverse and power modifiers. OptimizeAnnotated initializer. @@ -27,6 +28,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeAnnotated * **equivalence\_library** – The equivalence library used (instructions in this library will not be optimized by this pass). * **basis\_gates** – Optional, target basis names to unroll to, e.g. \[‘u3’, ‘cx’] (instructions in this list will not be optimized by this pass). Ignored if `target` is also specified. * **recurse** – By default, when either `target` or `basis_gates` is specified, the pass recursively descends into gate definitions (and the recursion is not applied when neither is specified since such objects do not need to be synthesized). Setting this value to `False` precludes the recursion in every case. + * **do\_conjugate\_reduction** – controls whether conjugate reduction should be performed. ## Attributes @@ -50,7 +52,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeAnnotated ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -70,7 +72,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeAnnotated ### name - + Name of the pass. **Return type** @@ -80,7 +82,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeAnnotated ### run - + Run the OptimizeAnnotated pass on dag. **Parameters** @@ -98,7 +100,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeAnnotated ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.OptimizeCliffords.mdx b/docs/api/qiskit/qiskit.transpiler.passes.OptimizeCliffords.mdx index 88a3e5c68f2..aa78eedd830 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.OptimizeCliffords.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.OptimizeCliffords.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeCliffords # OptimizeCliffords - + 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. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeCliffords ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeCliffords ### name - + Name of the pass. **Return type** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeCliffords ### run - + Run the OptimizeCliffords pass on dag. **Parameters** @@ -83,7 +83,7 @@ python_api_name: qiskit.transpiler.passes.OptimizeCliffords ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.PadDelay.mdx b/docs/api/qiskit/qiskit.transpiler.passes.PadDelay.mdx index 12546defb2b..587089d3bbe 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.PadDelay.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.PadDelay.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.PadDelay # PadDelay - + Bases: `BasePadding` Padding idle time with Delay instructions. @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.PadDelay ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -87,7 +87,7 @@ python_api_name: qiskit.transpiler.passes.PadDelay ### name - + Name of the pass. **Return type** @@ -97,7 +97,7 @@ python_api_name: qiskit.transpiler.passes.PadDelay ### run - + Run the padding pass on `dag`. **Parameters** @@ -119,7 +119,7 @@ python_api_name: qiskit.transpiler.passes.PadDelay ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.PadDynamicalDecoupling.mdx b/docs/api/qiskit/qiskit.transpiler.passes.PadDynamicalDecoupling.mdx index 67fc7433441..faec31fc5c0 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.PadDynamicalDecoupling.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.PadDynamicalDecoupling.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.PadDynamicalDecoupling # PadDynamicalDecoupling - + Bases: `BasePadding` Dynamical decoupling insertion pass. @@ -125,7 +125,7 @@ python_api_name: qiskit.transpiler.passes.PadDynamicalDecoupling ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -145,7 +145,7 @@ python_api_name: qiskit.transpiler.passes.PadDynamicalDecoupling ### name - + Name of the pass. **Return type** @@ -155,7 +155,7 @@ python_api_name: qiskit.transpiler.passes.PadDynamicalDecoupling ### run - + Run the padding pass on `dag`. **Parameters** @@ -177,7 +177,7 @@ python_api_name: qiskit.transpiler.passes.PadDynamicalDecoupling ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.PulseGates.mdx b/docs/api/qiskit/qiskit.transpiler.passes.PulseGates.mdx index a1b3d65957c..f3cceeab4f4 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.PulseGates.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.PulseGates.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.PulseGates # PulseGates - + Bases: `CalibrationBuilder` Pulse gate adding pass. @@ -54,7 +54,7 @@ python_api_name: qiskit.transpiler.passes.PulseGates ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -74,7 +74,7 @@ python_api_name: qiskit.transpiler.passes.PulseGates ### get\_calibration - + Gets the calibrated schedule for the given instruction and qubits. **Parameters** @@ -97,7 +97,7 @@ python_api_name: qiskit.transpiler.passes.PulseGates ### name - + Name of the pass. **Return type** @@ -107,7 +107,7 @@ python_api_name: qiskit.transpiler.passes.PulseGates ### run - + Run the calibration adder pass on dag. **Parameters** @@ -125,7 +125,7 @@ python_api_name: qiskit.transpiler.passes.PulseGates ### supported - + Determine if a given node supports the calibration. **Parameters** @@ -144,7 +144,7 @@ python_api_name: qiskit.transpiler.passes.PulseGates ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.RXCalibrationBuilder.mdx b/docs/api/qiskit/qiskit.transpiler.passes.RXCalibrationBuilder.mdx index 591dd5407b3..30d092d3e5b 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.RXCalibrationBuilder.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.RXCalibrationBuilder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.RXCalibrationBuilder # RXCalibrationBuilder - + Bases: `CalibrationBuilder` Add single-pulse RX calibrations that are bootstrapped from the SX calibration. @@ -85,7 +85,7 @@ python_api_name: qiskit.transpiler.passes.RXCalibrationBuilder ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -105,7 +105,7 @@ python_api_name: qiskit.transpiler.passes.RXCalibrationBuilder ### get\_calibration - + Generate RX calibration for the rotation angle specified in node\_op. **Return type** @@ -115,7 +115,7 @@ python_api_name: qiskit.transpiler.passes.RXCalibrationBuilder ### name - + Name of the pass. **Return type** @@ -125,7 +125,7 @@ python_api_name: qiskit.transpiler.passes.RXCalibrationBuilder ### run - + Run the calibration adder pass on dag. **Parameters** @@ -143,7 +143,7 @@ python_api_name: qiskit.transpiler.passes.RXCalibrationBuilder ### supported - + Check if the calibration for SX gate exists and it’s a single DRAG pulse. **Return type** @@ -153,7 +153,7 @@ python_api_name: qiskit.transpiler.passes.RXCalibrationBuilder ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.RZXCalibrationBuilder.mdx b/docs/api/qiskit/qiskit.transpiler.passes.RZXCalibrationBuilder.mdx index 910e676d8f1..62cc2809cb0 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.RZXCalibrationBuilder.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.RZXCalibrationBuilder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder # RZXCalibrationBuilder - + 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). @@ -47,7 +47,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder ### get\_calibration - + Builds the calibration schedule for the RZXGate(theta) with echos. **Parameters** @@ -92,7 +92,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder ### name - + Name of the pass. **Return type** @@ -102,7 +102,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder ### rescale\_cr\_inst - + A builder macro to play stretched pulse. **Parameters** @@ -126,7 +126,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder ### run - + Run the calibration adder pass on dag. **Parameters** @@ -144,7 +144,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder ### supported - + Determine if a given node supports the calibration. **Parameters** @@ -163,7 +163,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.mdx b/docs/api/qiskit/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.mdx index 6c55a815862..9877ba1f2c4 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho # RZXCalibrationBuilderNoEcho - + 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. @@ -49,7 +49,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho ### get\_calibration - + Builds the calibration schedule for the RZXGate(theta) without echos. **Parameters** @@ -94,7 +94,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho ### name - + Name of the pass. **Return type** @@ -104,7 +104,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho ### rescale\_cr\_inst - + A builder macro to play stretched pulse. **Parameters** @@ -128,7 +128,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho ### run - + Run the calibration adder pass on dag. **Parameters** @@ -146,7 +146,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho ### supported - + Determine if a given node supports the calibration. **Parameters** @@ -165,7 +165,7 @@ python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.RemoveBarriers.mdx b/docs/api/qiskit/qiskit.transpiler.passes.RemoveBarriers.mdx index 9cb26c9cf83..7f6dbdd2db9 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.RemoveBarriers.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.RemoveBarriers.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.RemoveBarriers # RemoveBarriers - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Return a circuit with any barrier removed. @@ -54,7 +54,7 @@ python_api_name: qiskit.transpiler.passes.RemoveBarriers ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -74,7 +74,7 @@ python_api_name: qiskit.transpiler.passes.RemoveBarriers ### name - + Name of the pass. **Return type** @@ -84,7 +84,7 @@ python_api_name: qiskit.transpiler.passes.RemoveBarriers ### run - + Run the RemoveBarriers pass on dag. **Return type** @@ -94,7 +94,7 @@ python_api_name: qiskit.transpiler.passes.RemoveBarriers ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.mdx b/docs/api/qiskit/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.mdx index cf7fc4286c8..ac4e53c4536 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure # RemoveDiagonalGatesBeforeMeasure - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Remove diagonal gates (including diagonal 2Q gates) before a measurement. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure ### name - + Name of the pass. **Return type** @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure ### run - + Run the RemoveDiagonalGatesBeforeMeasure pass on dag. **Parameters** @@ -85,7 +85,7 @@ python_api_name: qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.RemoveFinalMeasurements.mdx b/docs/api/qiskit/qiskit.transpiler.passes.RemoveFinalMeasurements.mdx index 907b14dabf0..97a92b1c1fd 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.RemoveFinalMeasurements.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.RemoveFinalMeasurements.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.RemoveFinalMeasurements # RemoveFinalMeasurements - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Remove final measurements and barriers at the end of a circuit. @@ -39,7 +39,7 @@ python_api_name: qiskit.transpiler.passes.RemoveFinalMeasurements ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -59,7 +59,7 @@ python_api_name: qiskit.transpiler.passes.RemoveFinalMeasurements ### name - + Name of the pass. **Return type** @@ -69,7 +69,7 @@ python_api_name: qiskit.transpiler.passes.RemoveFinalMeasurements ### run - + Run the RemoveFinalMeasurements pass on dag. **Parameters** @@ -87,7 +87,7 @@ python_api_name: qiskit.transpiler.passes.RemoveFinalMeasurements ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.RemoveFinalReset.mdx b/docs/api/qiskit/qiskit.transpiler.passes.RemoveFinalReset.mdx new file mode 100644 index 00000000000..1826b6f09dc --- /dev/null +++ b/docs/api/qiskit/qiskit.transpiler.passes.RemoveFinalReset.mdx @@ -0,0 +1,103 @@ +--- +title: RemoveFinalReset +description: API reference for qiskit.transpiler.passes.RemoveFinalReset +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.RemoveFinalReset +--- + +# RemoveFinalReset + + + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + + Remove reset when it is the final instruction on a qubit wire. + + ## 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 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + Run the RemoveFinalReset 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 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/qiskit.transpiler.passes.RemoveResetInZeroState.mdx b/docs/api/qiskit/qiskit.transpiler.passes.RemoveResetInZeroState.mdx index 6e8bf935a49..bc1efd68c87 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.RemoveResetInZeroState.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.RemoveResetInZeroState.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.RemoveResetInZeroState # RemoveResetInZeroState - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Remove reset gate when the qubit is in zero state. @@ -35,7 +35,7 @@ python_api_name: qiskit.transpiler.passes.RemoveResetInZeroState ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -55,7 +55,7 @@ python_api_name: qiskit.transpiler.passes.RemoveResetInZeroState ### name - + Name of the pass. **Return type** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.RemoveResetInZeroState ### run - + Run the RemoveResetInZeroState pass on dag. **Parameters** @@ -83,7 +83,7 @@ python_api_name: qiskit.transpiler.passes.RemoveResetInZeroState ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.ResetAfterMeasureSimplification.mdx b/docs/api/qiskit/qiskit.transpiler.passes.ResetAfterMeasureSimplification.mdx index a606e7265ab..9e4a67f0f59 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.ResetAfterMeasureSimplification.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.ResetAfterMeasureSimplification.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ResetAfterMeasureSimplification # ResetAfterMeasureSimplification - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") This pass replaces reset after measure with a conditional X gate. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.ResetAfterMeasureSimplification ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.ResetAfterMeasureSimplification ### name - + Name of the pass. **Return type** @@ -67,13 +67,13 @@ python_api_name: qiskit.transpiler.passes.ResetAfterMeasureSimplification ### run - + Run the pass on a dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.SabreLayout.mdx b/docs/api/qiskit/qiskit.transpiler.passes.SabreLayout.mdx index 51bc94baa28..4ca5770c9f4 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.SabreLayout.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.SabreLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.SabreLayout # SabreLayout - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Choose a Layout via iterative bidirectional routing of the input circuit. @@ -129,7 +129,7 @@ python_api_name: qiskit.transpiler.passes.SabreLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -149,7 +149,7 @@ python_api_name: qiskit.transpiler.passes.SabreLayout ### name - + Name of the pass. **Return type** @@ -159,7 +159,7 @@ python_api_name: qiskit.transpiler.passes.SabreLayout ### run - + Run the SabreLayout pass on dag. **Parameters** @@ -183,7 +183,7 @@ python_api_name: qiskit.transpiler.passes.SabreLayout ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.SabrePreLayout.mdx b/docs/api/qiskit/qiskit.transpiler.passes.SabrePreLayout.mdx index aa08ccb5dcd..01e69504fad 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.SabrePreLayout.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.SabrePreLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.SabrePreLayout # SabrePreLayout - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Choose a starting layout to use for additional Sabre layout trials. @@ -99,7 +99,7 @@ python_api_name: qiskit.transpiler.passes.SabrePreLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -119,7 +119,7 @@ python_api_name: qiskit.transpiler.passes.SabrePreLayout ### name - + Name of the pass. **Return type** @@ -129,7 +129,7 @@ python_api_name: qiskit.transpiler.passes.SabrePreLayout ### run - + Run the SabrePreLayout pass on dag. The discovered starting layout is written to the property set value `sabre_starting_layouts`. @@ -141,7 +141,7 @@ python_api_name: qiskit.transpiler.passes.SabrePreLayout ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.SabreSwap.mdx b/docs/api/qiskit/qiskit.transpiler.passes.SabreSwap.mdx index ac65f99a073..834a5f984bb 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.SabreSwap.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.SabreSwap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.SabreSwap # SabreSwap - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Map input circuit onto a backend topology via insertion of SWAPs. @@ -95,7 +95,7 @@ python_api_name: qiskit.transpiler.passes.SabreSwap ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -115,7 +115,7 @@ python_api_name: qiskit.transpiler.passes.SabreSwap ### name - + Name of the pass. **Return type** @@ -125,7 +125,7 @@ python_api_name: qiskit.transpiler.passes.SabreSwap ### run - + Run the SabreSwap pass on dag. **Parameters** @@ -148,7 +148,7 @@ python_api_name: qiskit.transpiler.passes.SabreSwap ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.SetIOLatency.mdx b/docs/api/qiskit/qiskit.transpiler.passes.SetIOLatency.mdx index 9d68f6093a1..b4c5096f538 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.SetIOLatency.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.SetIOLatency.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.SetIOLatency # SetIOLatency - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Set IOLatency information to the input circuit. @@ -46,7 +46,7 @@ python_api_name: qiskit.transpiler.passes.SetIOLatency ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -66,7 +66,7 @@ python_api_name: qiskit.transpiler.passes.SetIOLatency ### name - + Name of the pass. **Return type** @@ -76,7 +76,7 @@ python_api_name: qiskit.transpiler.passes.SetIOLatency ### run - + Add IO latency information. **Parameters** @@ -86,7 +86,7 @@ python_api_name: qiskit.transpiler.passes.SetIOLatency ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.SetLayout.mdx b/docs/api/qiskit/qiskit.transpiler.passes.SetLayout.mdx index 57ec405f824..f71be5a2e41 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.SetLayout.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.SetLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.SetLayout # SetLayout - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Set the `layout` property to the given layout. @@ -48,7 +48,7 @@ python_api_name: qiskit.transpiler.passes.SetLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -68,7 +68,7 @@ python_api_name: qiskit.transpiler.passes.SetLayout ### name - + Name of the pass. **Return type** @@ -78,7 +78,7 @@ python_api_name: qiskit.transpiler.passes.SetLayout ### run - + Run the SetLayout pass on `dag`. **Parameters** @@ -96,7 +96,7 @@ python_api_name: qiskit.transpiler.passes.SetLayout ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.Size.mdx b/docs/api/qiskit/qiskit.transpiler.passes.Size.mdx index b79673ed7ef..aded199863e 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.Size.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.Size.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Size # Size - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Calculate the size of a DAG circuit. @@ -41,7 +41,7 @@ python_api_name: qiskit.transpiler.passes.Size ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -61,7 +61,7 @@ python_api_name: qiskit.transpiler.passes.Size ### name - + Name of the pass. **Return type** @@ -71,13 +71,13 @@ python_api_name: qiskit.transpiler.passes.Size ### run - + Run the Size pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.SolovayKitaev.mdx b/docs/api/qiskit/qiskit.transpiler.passes.SolovayKitaev.mdx index 3338fd87067..f8abed0e116 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.SolovayKitaev.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.SolovayKitaev.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.SolovayKitaev # SolovayKitaev - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Approximately decompose 1q gates to a discrete basis using the Solovay-Kitaev algorithm. @@ -124,7 +124,7 @@ python_api_name: qiskit.transpiler.passes.SolovayKitaev ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -144,7 +144,7 @@ python_api_name: qiskit.transpiler.passes.SolovayKitaev ### name - + Name of the pass. **Return type** @@ -154,7 +154,7 @@ python_api_name: qiskit.transpiler.passes.SolovayKitaev ### run - + Run the `SolovayKitaev` pass on dag. **Parameters** @@ -176,7 +176,7 @@ python_api_name: qiskit.transpiler.passes.SolovayKitaev ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.StarPreRouting.mdx b/docs/api/qiskit/qiskit.transpiler.passes.StarPreRouting.mdx new file mode 100644 index 00000000000..d5687d3005c --- /dev/null +++ b/docs/api/qiskit/qiskit.transpiler.passes.StarPreRouting.mdx @@ -0,0 +1,164 @@ +--- +title: StarPreRouting +description: API reference for qiskit.transpiler.passes.StarPreRouting +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.StarPreRouting +--- + +# StarPreRouting + + + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + + Run star to linear pre-routing + + This pass is a logical optimization pass that rewrites any solely 2q gate star connectivity subcircuit as a linear connectivity equivalent with swaps. + + For example: + + > ```python + > from qiskit.circuit import QuantumCircuit + > from qiskit.transpiler.passes import StarPreRouting + > + > qc = QuantumCircuit(10) + > qc.h(0) + > qc.cx(0, range(1, 5)) + > qc.h(9) + > qc.cx(9, range(8, 4, -1)) + > qc.measure_all() + > StarPreRouting()(qc).draw("mpl") + > ``` + > + > ![../\_images/qiskit-transpiler-passes-StarPreRouting-1.png](/images/api/qiskit/qiskit-transpiler-passes-StarPreRouting-1.png) + + This pass was inspired by a similar pass described in Section IV of: C. Campbell et al., “Superstaq: Deep Optimization of Quantum Programs,” 2023 IEEE International Conference on Quantum Computing and Engineering (QCE), Bellevue, WA, USA, 2023, pp. 1020-1032, doi: 10.1109/QCE57702.2023.00116. + + ## 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 + + ### collect\_all\_matching\_blocks + + + Collects all blocks that match a given filtering function filter\_fn. This iteratively finds the largest block that does not match filter\_fn, then the largest block that matches filter\_fn, and so on, until no more uncollected nodes remain. Intuitively, finding larger blocks of non-matching nodes helps to find larger blocks of matching nodes later on. The option `min_block_size` specifies the minimum number of gates in the block for the block to be collected. + + By default, blocks are collected in the direction from the inputs towards the outputs of the circuit. The option `collect_from_back` allows to change this direction, that is collect blocks from the outputs towards the inputs of the circuit. + + Returns the list of matching blocks only. + + + ### collect\_matching\_block + + + Iteratively collects the largest block of input nodes (that is, nodes with `_in_degree` equal to 0) that match a given filtering function. Examples of this include collecting blocks of swap gates, blocks of linear gates (CXs and SWAPs), blocks of Clifford gates, blocks of single-qubit gates, blocks of two-qubit gates, etc. Here ‘iteratively’ means that once a node is collected, the `_in_degree` of each of its immediate successor is decreased by 1, allowing more nodes to become input and to be eligible for collecting into the current block. Returns the block of collected nodes. + + + ### determine\_star\_blocks\_processing + + + Returns star blocks in dag and the processing order of nodes within these star blocks :param dag: a dag on which star blocks should be determined. :type dag: DAGCircuit or DAGDependency :param min\_block\_size: minimum number of two-qubit gates in a star block. :type min\_block\_size: int + + **Returns** + + a list of star blocks in the given dag Union\[List\[DAGOpNode], List\[DAGDepNode]]: a list of operations specifying processing order + + **Return type** + + List\[StarBlock] + + + ### execute + + + 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 of the pass. + + **Return type** + + [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + ### run + + + 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. + + + ### star\_preroute + + + Returns star blocks in dag and the processing order of nodes within these star blocks :param dag: a dag on which star prerouting should be performed. :type dag: DAGCircuit or DAGDependency :param blocks: a list of star blocks in the given dag. :type blocks: List\[StarBlock] :param processing\_order: a list of operations specifying :type processing\_order: Union\[List\[DAGOpNode], List\[DAGDepNode]] :param processing order: + + **Returns** + + a dag specifying the pre-routed circuit qubit\_mapping: the final qubit mapping after pre-routing + + **Return type** + + new\_dag + + + ### update\_status + + + 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/qiskit.transpiler.passes.StochasticSwap.mdx b/docs/api/qiskit/qiskit.transpiler.passes.StochasticSwap.mdx index 8e98bbb0eed..82b1b645dc0 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.StochasticSwap.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.StochasticSwap.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.StochasticSwap # StochasticSwap - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Map a DAGCircuit onto a coupling\_map adding swap gates. @@ -56,7 +56,7 @@ python_api_name: qiskit.transpiler.passes.StochasticSwap ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -76,7 +76,7 @@ python_api_name: qiskit.transpiler.passes.StochasticSwap ### name - + Name of the pass. **Return type** @@ -86,7 +86,7 @@ python_api_name: qiskit.transpiler.passes.StochasticSwap ### run - + Run the StochasticSwap pass on dag. **Parameters** @@ -109,7 +109,7 @@ python_api_name: qiskit.transpiler.passes.StochasticSwap ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.TemplateOptimization.mdx b/docs/api/qiskit/qiskit.transpiler.passes.TemplateOptimization.mdx index e2e2637dfb8..ff84ea2f4f3 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.TemplateOptimization.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.TemplateOptimization.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.TemplateOptimization # TemplateOptimization - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Class for the template optimization pass. @@ -42,7 +42,7 @@ python_api_name: qiskit.transpiler.passes.TemplateOptimization ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -62,7 +62,7 @@ python_api_name: qiskit.transpiler.passes.TemplateOptimization ### name - + Name of the pass. **Return type** @@ -72,7 +72,7 @@ python_api_name: qiskit.transpiler.passes.TemplateOptimization ### run - + **Parameters** **dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG circuit. @@ -92,7 +92,7 @@ python_api_name: qiskit.transpiler.passes.TemplateOptimization ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.TimeUnitConversion.mdx b/docs/api/qiskit/qiskit.transpiler.passes.TimeUnitConversion.mdx index 04d0a90fceb..0e9d282c227 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.TimeUnitConversion.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.TimeUnitConversion.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.TimeUnitConversion # TimeUnitConversion - + 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. @@ -50,7 +50,7 @@ python_api_name: qiskit.transpiler.passes.TimeUnitConversion ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -70,7 +70,7 @@ python_api_name: qiskit.transpiler.passes.TimeUnitConversion ### name - + Name of the pass. **Return type** @@ -80,7 +80,7 @@ python_api_name: qiskit.transpiler.passes.TimeUnitConversion ### run - + Run the TimeUnitAnalysis pass on dag. **Parameters** @@ -102,7 +102,7 @@ python_api_name: qiskit.transpiler.passes.TimeUnitConversion ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.TranslateParameterizedGates.mdx b/docs/api/qiskit/qiskit.transpiler.passes.TranslateParameterizedGates.mdx index 234d5354057..75c54e95fcb 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.TranslateParameterizedGates.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.TranslateParameterizedGates.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.TranslateParameterizedGates # TranslateParameterizedGates - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Translate parameterized gates to a supported basis set. @@ -92,7 +92,7 @@ python_api_name: qiskit.transpiler.passes.TranslateParameterizedGates ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -112,7 +112,7 @@ python_api_name: qiskit.transpiler.passes.TranslateParameterizedGates ### name - + Name of the pass. **Return type** @@ -122,7 +122,7 @@ python_api_name: qiskit.transpiler.passes.TranslateParameterizedGates ### run - + Run the transpiler pass. **Parameters** @@ -144,7 +144,7 @@ python_api_name: qiskit.transpiler.passes.TranslateParameterizedGates ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.TrivialLayout.mdx b/docs/api/qiskit/qiskit.transpiler.passes.TrivialLayout.mdx index 7686c8c4b0b..d9693942173 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.TrivialLayout.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.TrivialLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.TrivialLayout # TrivialLayout - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Choose a Layout by assigning `n` circuit qubits to device qubits `0, .., n-1`. @@ -51,7 +51,7 @@ python_api_name: qiskit.transpiler.passes.TrivialLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -71,7 +71,7 @@ python_api_name: qiskit.transpiler.passes.TrivialLayout ### name - + Name of the pass. **Return type** @@ -81,7 +81,7 @@ python_api_name: qiskit.transpiler.passes.TrivialLayout ### run - + Run the TrivialLayout pass on dag. **Parameters** @@ -95,7 +95,7 @@ python_api_name: qiskit.transpiler.passes.TrivialLayout ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.UnitarySynthesis.mdx b/docs/api/qiskit/qiskit.transpiler.passes.UnitarySynthesis.mdx index 16bf02d5ea4..e344ea9e3ed 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.UnitarySynthesis.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.UnitarySynthesis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.UnitarySynthesis # UnitarySynthesis - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Synthesize gates according to their basis gates. @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.UnitarySynthesis ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -77,7 +77,7 @@ python_api_name: qiskit.transpiler.passes.UnitarySynthesis ### name - + Name of the pass. **Return type** @@ -87,7 +87,7 @@ python_api_name: qiskit.transpiler.passes.UnitarySynthesis ### run - + Run the UnitarySynthesis pass on `dag`. **Parameters** @@ -105,7 +105,7 @@ python_api_name: qiskit.transpiler.passes.UnitarySynthesis ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.Unroll3qOrMore.mdx b/docs/api/qiskit/qiskit.transpiler.passes.Unroll3qOrMore.mdx index 3bb2ec28311..e07f6ddf70c 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.Unroll3qOrMore.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.Unroll3qOrMore.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Unroll3qOrMore # Unroll3qOrMore - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Recursively expands 3q+ gates until the circuit only contains 2q or 1q gates. @@ -42,7 +42,7 @@ python_api_name: qiskit.transpiler.passes.Unroll3qOrMore ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -62,7 +62,7 @@ python_api_name: qiskit.transpiler.passes.Unroll3qOrMore ### name - + Name of the pass. **Return type** @@ -72,7 +72,7 @@ python_api_name: qiskit.transpiler.passes.Unroll3qOrMore ### run - + Run the Unroll3qOrMore pass on dag. **Parameters** @@ -94,7 +94,7 @@ python_api_name: qiskit.transpiler.passes.Unroll3qOrMore ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.UnrollCustomDefinitions.mdx b/docs/api/qiskit/qiskit.transpiler.passes.UnrollCustomDefinitions.mdx index d7a9c76b4a3..b05d842181c 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.UnrollCustomDefinitions.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.UnrollCustomDefinitions.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.UnrollCustomDefinitions # UnrollCustomDefinitions - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") Unrolls instructions with custom definitions. @@ -53,7 +53,7 @@ python_api_name: qiskit.transpiler.passes.UnrollCustomDefinitions ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -73,7 +73,7 @@ python_api_name: qiskit.transpiler.passes.UnrollCustomDefinitions ### name - + Name of the pass. **Return type** @@ -83,7 +83,7 @@ python_api_name: qiskit.transpiler.passes.UnrollCustomDefinitions ### run - + Run the UnrollCustomDefinitions pass on dag. **Parameters** @@ -106,7 +106,7 @@ python_api_name: qiskit.transpiler.passes.UnrollCustomDefinitions ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.UnrollForLoops.mdx b/docs/api/qiskit/qiskit.transpiler.passes.UnrollForLoops.mdx index 478fa2ca07a..fed1849a940 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.UnrollForLoops.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.UnrollForLoops.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.UnrollForLoops # UnrollForLoops - + Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") `UnrollForLoops` transpilation pass unrolls for-loops when possible. @@ -45,7 +45,7 @@ python_api_name: qiskit.transpiler.passes.UnrollForLoops ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -65,7 +65,7 @@ python_api_name: qiskit.transpiler.passes.UnrollForLoops ### name - + Name of the pass. **Return type** @@ -75,7 +75,7 @@ python_api_name: qiskit.transpiler.passes.UnrollForLoops ### run - + Run the UnrollForLoops pass on `dag`. **Parameters** @@ -93,7 +93,7 @@ python_api_name: qiskit.transpiler.passes.UnrollForLoops ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.VF2Layout.mdx b/docs/api/qiskit/qiskit.transpiler.passes.VF2Layout.mdx index 6a5eeedcaa1..e43a5257d7a 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.VF2Layout.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.VF2Layout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.VF2Layout # VF2Layout - + 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++. @@ -71,7 +71,7 @@ python_api_name: qiskit.transpiler.passes.VF2Layout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -91,7 +91,7 @@ python_api_name: qiskit.transpiler.passes.VF2Layout ### name - + Name of the pass. **Return type** @@ -101,13 +101,13 @@ python_api_name: qiskit.transpiler.passes.VF2Layout ### run - + run the layout method ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.VF2PostLayout.mdx b/docs/api/qiskit/qiskit.transpiler.passes.VF2PostLayout.mdx index 8eb9eada142..a5482043e15 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.VF2PostLayout.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.VF2PostLayout.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.VF2PostLayout # VF2PostLayout - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") A pass for improving an existing Layout after transpilation of a circuit onto a Coupling graph, as a subgraph isomorphism problem, solved by VF2++. @@ -74,7 +74,7 @@ python_api_name: qiskit.transpiler.passes.VF2PostLayout ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -94,7 +94,7 @@ python_api_name: qiskit.transpiler.passes.VF2PostLayout ### name - + Name of the pass. **Return type** @@ -104,13 +104,13 @@ python_api_name: qiskit.transpiler.passes.VF2PostLayout ### run - + run the layout method ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.ValidatePulseGates.mdx b/docs/api/qiskit/qiskit.transpiler.passes.ValidatePulseGates.mdx index 802a45f4590..f52be5fb92b 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.ValidatePulseGates.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.ValidatePulseGates.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.ValidatePulseGates # ValidatePulseGates - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Check custom gate length. @@ -27,6 +27,7 @@ python_api_name: qiskit.transpiler.passes.ValidatePulseGates * **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. + * **target** – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if `target` is specified then this argument will take precedence and `granularity` and `min_length` will be ignored. ## Attributes @@ -50,7 +51,7 @@ python_api_name: qiskit.transpiler.passes.ValidatePulseGates ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -70,7 +71,7 @@ python_api_name: qiskit.transpiler.passes.ValidatePulseGates ### name - + Name of the pass. **Return type** @@ -80,7 +81,7 @@ python_api_name: qiskit.transpiler.passes.ValidatePulseGates ### run - + Run the pulse gate validation attached to `dag`. **Parameters** @@ -102,7 +103,7 @@ python_api_name: qiskit.transpiler.passes.ValidatePulseGates ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.Width.mdx b/docs/api/qiskit/qiskit.transpiler.passes.Width.mdx index 2cca67ecf72..25e2c19a066 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.Width.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.Width.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.Width # Width - + Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") Calculate the width of a DAG circuit. @@ -37,7 +37,7 @@ python_api_name: qiskit.transpiler.passes.Width ### execute - + Execute optimization task for input Qiskit IR. **Parameters** @@ -57,7 +57,7 @@ python_api_name: qiskit.transpiler.passes.Width ### name - + Name of the pass. **Return type** @@ -67,13 +67,13 @@ python_api_name: qiskit.transpiler.passes.Width ### run - + Run the Width pass on dag. ### update\_status - + Update workflow status. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin.mdx index 631e5e1bf1d..184f9564360 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugin.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugi # AQCSynthesisPlugin - + Bases: [`UnitarySynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin") An AQC-based Qiskit unitary synthesis plugin. @@ -157,7 +157,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.aqc_plugin.AQCSynthesisPlugi ### run - + Run synthesis for the given unitary matrix **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation.mdx index a45ffc142c7..36be49933e7 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynthesisPermutation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynt # ACGSynthesisPermutation - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") The permutation synthesis plugin based on the Alon, Chung, Graham method. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.ACGSynt ### run - + Run synthesis for the given Permutation. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford.mdx index e02ff9ca2b2..1da0a01c7f2 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynthesisClifford.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynth # AGSynthesisClifford - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") Clifford synthesis plugin based on the Aaronson-Gottesman method. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.AGSynth ### run - + Run synthesis for the given Clifford. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford.mdx index aa8c39dfcae..7843a1fab61 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynthesisClifford.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynth # BMSynthesisClifford - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") Clifford synthesis plugin based on the Bravyi-Maslov method. @@ -21,7 +21,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.BMSynth ### run - + Run synthesis for the given Clifford. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation.mdx index bdf0d5da614..ec41ef751ea 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSynthesisPermutation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSy # BasicSynthesisPermutation - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") The permutation synthesis plugin based on sorting. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.BasicSy ### run - + Run synthesis for the given Permutation. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford.mdx index 503b4e865aa..0300fc677d8 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisClifford.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.Default # DefaultSynthesisClifford - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") The default clifford synthesis plugin. @@ -21,7 +21,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.Default ### run - + Run synthesis for the given Clifford. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction.mdx index 4b7b29aa307..636517c9971 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.DefaultSynthesisLinearFunction.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.Default # DefaultSynthesisLinearFunction - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") The default linear function synthesis plugin. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.Default ### run - + Run synthesis for the given LinearFunction. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford.mdx index 091d0432b03..d7df7bb3586 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedySynthesisClifford.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedyS # GreedySynthesisClifford - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") Clifford synthesis plugin based on the greedy synthesis Bravyi-Hu-Maslov-Shaydulin method. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.GreedyS ### run - + Run synthesis for the given Clifford. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction.mdx index 8bb9ab53c64..e9ec256ccb4 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction.mdx @@ -8,18 +8,28 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynt # KMSSynthesisLinearFunction - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") Linear function synthesis plugin based on the Kutin-Moulton-Smithline method. This plugin name is :`linear_function.kms` which can be used as the key on an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.HLSConfig") object to use this method with [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis"). + The plugin supports the following plugin-specific options: + + * **use\_inverted: Indicates whether to run the algorithm on the inverse matrix** + + and to invert the synthesized circuit. In certain cases this provides a better decomposition than the direct approach. + + * **use\_transposed: Indicates whether to run the algorithm on the transposed matrix** + + and to invert the order of CX gates in the synthesized circuit. In certain cases this provides a better decomposition than the direct approach. + ## Methods ### run - + Run synthesis for the given LinearFunction. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation.mdx index e0c815c0c58..336d0608ed0 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisPermutation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynt # KMSSynthesisPermutation - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") The permutation synthesis plugin based on the Kutin, Moulton, Smithline method. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynt ### run - + Run synthesis for the given Permutation. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford.mdx index 98668534620..29cb813a391 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLnnSynthesisClifford.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLn # LayerLnnSynthesisClifford - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") Clifford synthesis plugin based on the Bravyi-Maslov method to synthesize Cliffords into layers, with each layer synthesized adhering to LNN connectivity. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerLn ### run - + Run synthesis for the given Clifford. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford.mdx index 22530da0228..8d785971280 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSynthesisClifford.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSy # LayerSynthesisClifford - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") Clifford synthesis plugin based on the Bravyi-Maslov method to synthesize Cliffords into layers. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.LayerSy ### run - + Run synthesis for the given Clifford. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction.mdx index 44671845c1f..b8296d28346 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction.mdx @@ -8,18 +8,34 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynt # PMHSynthesisLinearFunction - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") Linear function synthesis plugin based on the Patel-Markov-Hayes method. This plugin name is :`linear_function.pmh` which can be used as the key on an [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.synthesis.high_level_synthesis.HLSConfig") object to use this method with [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis"). + The plugin supports the following plugin-specific options: + + * section size: The size of each section used in the Patel–Markov–Hayes algorithm \[1]. + + * **use\_inverted: Indicates whether to run the algorithm on the inverse matrix** + + and to invert the synthesized circuit. In certain cases this provides a better decomposition than the direct approach. + + * **use\_transposed: Indicates whether to run the algorithm on the transposed matrix** + + and to invert the order of CX gates in the synthesized circuit. In certain cases this provides a better decomposition than the direct approach. + + **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) + ## Methods ### run - + Run synthesis for the given LinearFunction. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation.mdx index 65a1e1002fa..bd66dde11fd 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSwapperSynthesisPermutation.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSw # TokenSwapperSynthesisPermutation - + Bases: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") The permutation synthesis plugin based on the token swapper algorithm. @@ -33,7 +33,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.high_level_synthesis.TokenSw ### run - + Run synthesis for the given Permutation. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.mdx index 43a52a7a3d6..a4932f2f690 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlu # HighLevelSynthesisPlugin - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Abstract high-level synthesis plugin class. @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlu ### run - + Run synthesis for the given Operation. **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.mdx index a9d226762fc..9c24c885455 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlu # HighLevelSynthesisPluginManager - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Class tracking the installed high-level-synthesis plugins. @@ -17,13 +17,13 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlu ### method - + Returns the plugin for `op_name` and `method_name`. ### method\_names - + Returns plugin methods for op\_name. diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.mdx index 4d6a8081656..d574cae3f20 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugi # UnitarySynthesisPlugin - + Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") Abstract unitary synthesis plugin class @@ -176,7 +176,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugi ### run - + Run synthesis for the given unitary matrix **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.mdx index f9248907db3..5d2ecc20e2b 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugi # UnitarySynthesisPluginManager - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Unitary Synthesis plugin manager class diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names.mdx index b58b853d0e0..2c1895a4cea 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_ # qiskit.transpiler.passes.synthesis.plugin.high\_level\_synthesis\_plugin\_names - + Return a list of plugin names installed for a given high level object name **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.mdx index 582f866f69d..668e073fcad 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plu # qiskit.transpiler.passes.synthesis.plugin.unitary\_synthesis\_plugin\_names - + Return a list of installed unitary synthesis plugin names **Returns** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis.mdx index b1ada293692..d438df741f6 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.SolovayKitaevSynthesis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.Sol # SolovayKitaevSynthesis - + Bases: [`UnitarySynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin") A Solovay-Kitaev Qiskit unitary synthesis plugin. @@ -149,7 +149,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.solovay_kitaev_synthesis.Sol ### run - + Run synthesis for the given unitary matrix **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis.mdx b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis.mdx index 2064046c12e..b1084da5a62 100644 --- a/docs/api/qiskit/qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis.mdx +++ b/docs/api/qiskit/qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUnitarySynthesis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUni # DefaultUnitarySynthesis - + Bases: [`UnitarySynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin") The default unitary synthesis plugin. @@ -67,7 +67,7 @@ python_api_name: qiskit.transpiler.passes.synthesis.unitary_synthesis.DefaultUni ### run - + Run synthesis for the given unitary matrix **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.mdx b/docs/api/qiskit/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.mdx index b21c2efe90f..9f809666a39 100644 --- a/docs/api/qiskit/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.mdx +++ b/docs/api/qiskit/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePl # PassManagerStagePlugin - + 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"). @@ -19,7 +19,7 @@ python_api_name: qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePl ### pass\_manager - + This method is designed to return a [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") for the stage this implements **Parameters** diff --git a/docs/api/qiskit/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.mdx b/docs/api/qiskit/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.mdx index b60c7c91c08..f1716499f03 100644 --- a/docs/api/qiskit/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.mdx +++ b/docs/api/qiskit/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePl # PassManagerStagePluginManager - + Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") Manager class for preset pass manager stage plugins. @@ -17,7 +17,7 @@ python_api_name: qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePl ### get\_passmanager\_stage - + Get a stage **Return type** diff --git a/docs/api/qiskit/qiskit.visualization.array_to_latex.mdx b/docs/api/qiskit/qiskit.visualization.array_to_latex.mdx index 94603dc1d82..66fbf7086ff 100644 --- a/docs/api/qiskit/qiskit.visualization.array_to_latex.mdx +++ b/docs/api/qiskit/qiskit.visualization.array_to_latex.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.array_to_latex # qiskit.visualization.array\_to\_latex - + Latex representation of a complex numpy array (with dimension 1 or 2) **Parameters** diff --git a/docs/api/qiskit/qiskit.visualization.circuit_drawer.mdx b/docs/api/qiskit/qiskit.visualization.circuit_drawer.mdx index e71f71e8e96..2968587cc66 100644 --- a/docs/api/qiskit/qiskit.visualization.circuit_drawer.mdx +++ b/docs/api/qiskit/qiskit.visualization.circuit_drawer.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.circuit_drawer # qiskit.visualization.circuit\_drawer - + Draw the quantum circuit. Use the output parameter to choose the drawing format: **text**: ASCII art TextDrawing that can be printed in the console. diff --git a/docs/api/qiskit/qiskit.visualization.dag_drawer.mdx b/docs/api/qiskit/qiskit.visualization.dag_drawer.mdx index dbdab7055bd..d57394f7d31 100644 --- a/docs/api/qiskit/qiskit.visualization.dag_drawer.mdx +++ b/docs/api/qiskit/qiskit.visualization.dag_drawer.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.dag_drawer # qiskit.visualization.dag\_drawer - + 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)") function from the `rustworkx` package to draw the DAG. diff --git a/docs/api/qiskit/qiskit.visualization.pass_manager_drawer.mdx b/docs/api/qiskit/qiskit.visualization.pass_manager_drawer.mdx index 26a916011e8..02e293a41c7 100644 --- a/docs/api/qiskit/qiskit.visualization.pass_manager_drawer.mdx +++ b/docs/api/qiskit/qiskit.visualization.pass_manager_drawer.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.pass_manager_drawer # qiskit.visualization.pass\_manager\_drawer - + 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. diff --git a/docs/api/qiskit/qiskit.visualization.plot_bloch_multivector.mdx b/docs/api/qiskit/qiskit.visualization.plot_bloch_multivector.mdx index 2a01c99ff7d..7c1cf62eb98 100644 --- a/docs/api/qiskit/qiskit.visualization.plot_bloch_multivector.mdx +++ b/docs/api/qiskit/qiskit.visualization.plot_bloch_multivector.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_bloch_multivector # qiskit.visualization.plot\_bloch\_multivector - + 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. @@ -31,7 +31,7 @@ python_api_name: qiskit.visualization.plot_bloch_multivector **Return type** - [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.4)") + [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/_as_gen/matplotlib.figure.Figure.html#matplotlib.figure.Figure "(in Matplotlib v3.9.0)") **Raises** diff --git a/docs/api/qiskit/qiskit.visualization.plot_bloch_vector.mdx b/docs/api/qiskit/qiskit.visualization.plot_bloch_vector.mdx index 6626581fd50..36d144fc2ea 100644 --- a/docs/api/qiskit/qiskit.visualization.plot_bloch_vector.mdx +++ b/docs/api/qiskit/qiskit.visualization.plot_bloch_vector.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_bloch_vector # qiskit.visualization.plot\_bloch\_vector - + Plot the Bloch sphere. Plot a Bloch sphere with the specified coordinates, that can be given in both cartesian and spherical systems. @@ -19,7 +19,7 @@ python_api_name: qiskit.visualization.plot_bloch_vector * **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.4)")) – An Axes to use for rendering the bloch sphere + * **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.9.0)")) – 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. @@ -30,7 +30,7 @@ python_api_name: qiskit.visualization.plot_bloch_vector **Return type** - [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.4)") + [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/_as_gen/matplotlib.figure.Figure.html#matplotlib.figure.Figure "(in Matplotlib v3.9.0)") **Raises** diff --git a/docs/api/qiskit/qiskit.visualization.plot_circuit_layout.mdx b/docs/api/qiskit/qiskit.visualization.plot_circuit_layout.mdx index a8bbe11b2a3..32d6c121a5b 100644 --- a/docs/api/qiskit/qiskit.visualization.plot_circuit_layout.mdx +++ b/docs/api/qiskit/qiskit.visualization.plot_circuit_layout.mdx @@ -10,14 +10,22 @@ python_api_name: qiskit.visualization.plot_circuit_layout # qiskit.visualization.plot\_circuit\_layout - + 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’. + + * **view** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – + + How to label qubits in the layout. Options: + + * `"virtual"`: Label each qubit with the index of the virtual qubit that mapped to it. + * `"physical"`: Label each qubit with the index of the physical qubit that it corresponds to on the device. + * **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** diff --git a/docs/api/qiskit/qiskit.visualization.plot_coupling_map.mdx b/docs/api/qiskit/qiskit.visualization.plot_coupling_map.mdx index 4cd656536ad..404cffb7b0d 100644 --- a/docs/api/qiskit/qiskit.visualization.plot_coupling_map.mdx +++ b/docs/api/qiskit/qiskit.visualization.plot_coupling_map.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_coupling_map # qiskit.visualization.plot\_coupling\_map - + Plots an arbitrary coupling map of qubits (embedded in a plane). **Parameters** diff --git a/docs/api/qiskit/qiskit.visualization.plot_distribution.mdx b/docs/api/qiskit/qiskit.visualization.plot_distribution.mdx index c07b44b2cf8..484b81bb8f0 100644 --- a/docs/api/qiskit/qiskit.visualization.plot_distribution.mdx +++ b/docs/api/qiskit/qiskit.visualization.plot_distribution.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_distribution # qiskit.visualization.plot\_distribution - + Plot a distribution from input sampled data. **Parameters** @@ -24,7 +24,7 @@ python_api_name: qiskit.visualization.plot_distribution * **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.4)")) – 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. + * **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.9.0)")) – 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** diff --git a/docs/api/qiskit/qiskit.visualization.plot_error_map.mdx b/docs/api/qiskit/qiskit.visualization.plot_error_map.mdx index 61d39b44995..d70d652e1e1 100644 --- a/docs/api/qiskit/qiskit.visualization.plot_error_map.mdx +++ b/docs/api/qiskit/qiskit.visualization.plot_error_map.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_error_map # qiskit.visualization.plot\_error\_map - + Plots the error map of a given backend. **Parameters** diff --git a/docs/api/qiskit/qiskit.visualization.plot_gate_map.mdx b/docs/api/qiskit/qiskit.visualization.plot_gate_map.mdx index 9f3328bc699..8356386d713 100644 --- a/docs/api/qiskit/qiskit.visualization.plot_gate_map.mdx +++ b/docs/api/qiskit/qiskit.visualization.plot_gate_map.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_gate_map # qiskit.visualization.plot\_gate\_map - + Plots the gate map of a device. **Parameters** diff --git a/docs/api/qiskit/qiskit.visualization.plot_histogram.mdx b/docs/api/qiskit/qiskit.visualization.plot_histogram.mdx index 3cf0a33dde1..e59a9b0dbdd 100644 --- a/docs/api/qiskit/qiskit.visualization.plot_histogram.mdx +++ b/docs/api/qiskit/qiskit.visualization.plot_histogram.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_histogram # qiskit.visualization.plot\_histogram - + Plot a histogram of input counts data. **Parameters** @@ -24,7 +24,7 @@ python_api_name: qiskit.visualization.plot_histogram * **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.4)")) – 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. + * **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.9.0)")) – 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** diff --git a/docs/api/qiskit/qiskit.visualization.plot_state_city.mdx b/docs/api/qiskit/qiskit.visualization.plot_state_city.mdx index 442c9454bf6..8e8a9bec453 100644 --- a/docs/api/qiskit/qiskit.visualization.plot_state_city.mdx +++ b/docs/api/qiskit/qiskit.visualization.plot_state_city.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_state_city # qiskit.visualization.plot\_state\_city - + Plot the cityscape of quantum state. Plot two 3d bar graphs (two dimensional) of the real and imaginary part of the density matrix rho. @@ -22,8 +22,8 @@ python_api_name: qiskit.visualization.plot_state_city * **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.4)")) – 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.4)")) – 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. + * **ax\_real** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.9.0)")) – 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.9.0)")) – 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** @@ -31,7 +31,7 @@ python_api_name: qiskit.visualization.plot_state_city **Return type** - [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.4)") + [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/_as_gen/matplotlib.figure.Figure.html#matplotlib.figure.Figure "(in Matplotlib v3.9.0)") **Raises** diff --git a/docs/api/qiskit/qiskit.visualization.plot_state_hinton.mdx b/docs/api/qiskit/qiskit.visualization.plot_state_hinton.mdx index be68f87da35..1cc52541fef 100644 --- a/docs/api/qiskit/qiskit.visualization.plot_state_hinton.mdx +++ b/docs/api/qiskit/qiskit.visualization.plot_state_hinton.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_state_hinton # qiskit.visualization.plot\_state\_hinton - + 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. @@ -21,8 +21,8 @@ python_api_name: qiskit.visualization.plot_state_hinton * **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.4)")) – 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.4)")) – 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\_real** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.9.0)")) – 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.9.0)")) – 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** @@ -30,7 +30,7 @@ python_api_name: qiskit.visualization.plot_state_hinton **Return type** - [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.4)") + [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/_as_gen/matplotlib.figure.Figure.html#matplotlib.figure.Figure "(in Matplotlib v3.9.0)") **Raises** diff --git a/docs/api/qiskit/qiskit.visualization.plot_state_paulivec.mdx b/docs/api/qiskit/qiskit.visualization.plot_state_paulivec.mdx index da7dfe94ac0..8b8e57a70e1 100644 --- a/docs/api/qiskit/qiskit.visualization.plot_state_paulivec.mdx +++ b/docs/api/qiskit/qiskit.visualization.plot_state_paulivec.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.plot_state_paulivec # qiskit.visualization.plot\_state\_paulivec - + 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 @@ -28,7 +28,7 @@ $$ * **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.4)")) – 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. + * **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.9.0)")) – 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** @@ -36,7 +36,7 @@ $$ **Return type** - [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.4)") + [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/_as_gen/matplotlib.figure.Figure.html#matplotlib.figure.Figure "(in Matplotlib v3.9.0)") **Raises** diff --git a/docs/api/qiskit/qiskit.visualization.plot_state_qsphere.mdx b/docs/api/qiskit/qiskit.visualization.plot_state_qsphere.mdx index b024e07419d..c3dd3448132 100644 --- a/docs/api/qiskit/qiskit.visualization.plot_state_qsphere.mdx +++ b/docs/api/qiskit/qiskit.visualization.plot_state_qsphere.mdx @@ -10,14 +10,14 @@ python_api_name: qiskit.visualization.plot_state_qsphere # qiskit.visualization.plot\_state\_qsphere - + 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.4)")) – 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. + * **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.9.0)")) – 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. @@ -28,7 +28,7 @@ python_api_name: qiskit.visualization.plot_state_qsphere **Return type** - [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.4)") + [`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/_as_gen/matplotlib.figure.Figure.html#matplotlib.figure.Figure "(in Matplotlib v3.9.0)") **Raises** diff --git a/docs/api/qiskit/qiskit.visualization.timeline_drawer.mdx b/docs/api/qiskit/qiskit.visualization.timeline_drawer.mdx index f9c2726604b..705026a52d5 100644 --- a/docs/api/qiskit/qiskit.visualization.timeline_drawer.mdx +++ b/docs/api/qiskit/qiskit.visualization.timeline_drawer.mdx @@ -10,24 +10,32 @@ python_api_name: qiskit.visualization.timeline_drawer # qiskit.visualization.timeline\_drawer - + Generate visualization data for scheduled circuit programs. + + `qiskit.visualization.timeline.interface.draw()`’s argument `show_barriers` is pending deprecation as of qiskit 1.1.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 `plot_barriers`, which behaves identically. + + + + `qiskit.visualization.timeline.interface.draw()`’s argument `show_idle` is pending deprecation as of qiskit 1.1.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 `idle_wires`, which behaves identically. + + **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. + * **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)")*]*) – 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. + * **disable\_bits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[Bits]*) – 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. + * **idle\_wires** ([*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. + * **plot\_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. @@ -49,6 +57,10 @@ python_api_name: qiskit.visualization.timeline_drawer * **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. + * **show\_idle** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – DEPRECATED. + + * **show\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – DEPRECATED. + **Returns** Visualization output data. diff --git a/docs/api/qiskit/qiskit.visualization.visualize_transition.mdx b/docs/api/qiskit/qiskit.visualization.visualize_transition.mdx index 65288ac6a5b..6cbd3753000 100644 --- a/docs/api/qiskit/qiskit.visualization.visualize_transition.mdx +++ b/docs/api/qiskit/qiskit.visualization.visualize_transition.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit.visualization.visualize_transition # qiskit.visualization.visualize\_transition - + Creates animation showing transitions between states of a single qubit by applying quantum gates. **Parameters** diff --git a/docs/api/qiskit/qpy.mdx b/docs/api/qiskit/qpy.mdx index 2cc8ae9b9c4..8a66fecea68 100644 --- a/docs/api/qiskit/qpy.mdx +++ b/docs/api/qiskit/qpy.mdx @@ -20,7 +20,7 @@ python_api_name: 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 +## Basic Usage 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: @@ -53,11 +53,11 @@ and then loading that file will return a list with all the circuits > > twenty\_new\_bells = qpy.load(fd) -### API documentation +## API documentation -#### load +### load - + 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: @@ -100,9 +100,9 @@ and then loading that file will return a list with all the circuits [*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 +### dump - + 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. @@ -164,15 +164,29 @@ and then loading that file will return a list with all the circuits 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 +### QpyError - + Errors raised by the qpy module. Set the error message. -#### qiskit.qpy.QPY\_VERSION +When a lower-than-maximum target QPY version is set for serialization, but the object to be serialized contains features that cannot be represented in that format, a subclass of [`QpyError`](#qiskit.qpy.QpyError "qiskit.qpy.QpyError") is raised: + +### UnsupportedFeatureForVersion + + + QPY error raised when the target dump version is too low for a feature that is present in the object to be serialized. + + **Parameters** + + * **feature** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – a description of the problematic feature. + * **required** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the minimum version of QPY that would be required to represent this feature. + * **target** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the version of QPY that is being used in the serialization. + + +### qiskit.qpy.QPY\_VERSION The current QPY format version as of this release. This is the default value of the `version` keyword argument on [`qpy.dump()`](#qiskit.qpy.dump "qiskit.qpy.dump") and also the upper bound for accepted values for the same argument. This is also the upper bond on the versions supported by [`qpy.load()`](#qiskit.qpy.load "qiskit.qpy.load"). @@ -182,7 +196,7 @@ These functions will raise a custom subclass of [`QiskitError`](exceptions#qiski [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") -#### qiskit.qpy.QPY\_COMPATIBILITY\_VERSION +### qiskit.qpy.QPY\_COMPATIBILITY\_VERSION The current minimum compatibility QPY format version. This is the minimum version that [`qpy.dump()`](#qiskit.qpy.dump "qiskit.qpy.dump") will accept for the `version` keyword argument. [`qpy.load()`](#qiskit.qpy.load "qiskit.qpy.load") will be able to load all released format versions of QPY (up until `QPY_VERSION`). @@ -192,7 +206,7 @@ These functions will raise a custom subclass of [`QiskitError`](exceptions#qiski [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") -### QPY Compatibility +## 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. @@ -200,12 +214,16 @@ For example, if you generated a QPY file using qiskit-terra 0.18.1 you could loa If a feature being loaded is deprecated in the corresponding qiskit release, QPY will raise a [`QPYLoadingDeprecatedFeatureWarning`](#qiskit.qpy.QPYLoadingDeprecatedFeatureWarning "qiskit.qpy.QPYLoadingDeprecatedFeatureWarning") informing of the deprecation period and how the feature will be internally handled. -#### QPYLoadingDeprecatedFeatureWarning +### QPYLoadingDeprecatedFeatureWarning - + Visible deprecation warning for QPY loading functions without a stable point in the call stack. +### QPY format version history + +If you’re planning to load a QPY file between different Qiskit versions knowing which versions were available in a given release are useful. As the QPY is backwards compatible but not forwards compatible you need to ensure a given QPY format version was released in the release you’re calling [`load()`](#qiskit.qpy.load "qiskit.qpy.load") with. The following table lists the QPY versions that were supported in every Qiskit (and qiskit-terra prior to Qiskit 1.0.0) release going back to the introduction of QPY in qiskit-terra 0.18.0. + ## QPY Format @@ -241,10 +259,84 @@ All values use network byte order [\[1\]](#f1) (big endian) for cross platform c 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` +`HEADER | METADATA | REGISTERS | STANDALONE_VARS | CUSTOM_DEFINITIONS | INSTRUCTIONS` + +The `STANDALONE_VARS` are new in QPY version 12; before that, there was no data between `REGISTERS` and `CUSTOM_DEFINITIONS`. 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 12 + +Version 12 adds support for: + +* circuits containing memory-owning [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") variables. + +#### Changes to HEADER + +The HEADER struct for an individual circuit has added three `uint32_t` counts of the input, captured and locally declared variables in the circuit. The new form looks like: + +```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; + uint32_t num_vars; +} HEADER_V12; +``` + +The `HEADER_V12` struct is followed immediately by the same name, global-phase, metadata and register information as the V2 version of the header. Immediately following the registers is `num_vars` instances of `EXPR_VAR_STANDALONE` that define the variables in this circuit. After that, the data continues with custom definitions and instructions as in prior versions of QPY. + + + +#### EXPR\_VAR\_DECLARATION + +An `EXPR_VAR_DECLARATION` defines an [`expr.Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") instance that is standalone; that is, it represents a self-owned memory location rather than wrapping a [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") or [`ClassicalRegister`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister"). The payload is a C struct: + +```python +struct { + char uuid_bytes[16]; + char usage; + uint16_t name_size; +} +``` + +which is immediately followed by an `EXPR_TYPE` payload and then `name_size` bytes of UTF-8 encoding string data containing the name of the variable. + +The `char` usage type code takes the following values: + +| Type code | Meaning | +| --------- | ------------------------------------------- | +| `I` | An `input` variable to the circuit. | +| `C` | A `capture` variable to the circuit. | +| `L` | A locally declared variable to the circuit. | + + + +#### Changes to EXPR\_VAR + +The EXPR\_VAR variable has gained a new type code and payload, in addition to the pre-existing ones: + +| Python class | Type code | Payload | +| ------------ | --------- | ----------------------------------------------------------------------------------------------------------------------------------------------- | +| `UUID` | `U` | One `uint32_t` index of the variable into the series of `EXPR_VAR_STANDALONE` variables that were written immediately after the circuit header. | + +Notably, this new type-code indexes into pre-defined variables from the circuit header, rather than redefining the variable again in each location it is used. + +### Changes to EXPRESSION + +The EXPRESSION type code has a new possible entry, `i`, corresponding to [`expr.Index`](circuit_classical#qiskit.circuit.classical.expr.Index "qiskit.circuit.classical.expr.Index") nodes. + +| Qiskit class | Type code | Payload | Children | +| ------------------------------------------------------------------------------------------------------ | --------- | -------------------------------------------------------------------------------- | -------- | +| [`Index`](circuit_classical#qiskit.circuit.classical.expr.Index "qiskit.circuit.classical.expr.Index") | `i` | No additional payload. The children are the target and the index, in that order. | 2 | + ### Version 11 @@ -272,13 +364,16 @@ This is sufficient to store different types of modifiers required for serializin ### 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. +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. +* 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 +#### Changes to FILE\_HEADER The contents of FILE\_HEADER after V10 are defined as a C struct as: @@ -290,10 +385,10 @@ struct { uint8_t qiskit_patch_version; uint64_t num_circuits; char symbolic_encoding; -} +} FILE_HEADER_V10; ``` -#### LAYOUT +#### Changes to LAYOUT The `LAYOUT` struct is updated to have an additional `input_qubit_count` field. With version 10 the `LAYOUT` struct is now: @@ -352,10 +447,10 @@ A [`Type`](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit 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. | +| Python class | Type code | Payload | +| -------------------------------------------------------------------------------------------------- | --------- | --------------------------------------------------------------------------------------------------------------------------------------- | +| [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") | `C` | One `uint32_t index` that is the index of the [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") in the containing circuit. | +| [`ClassicalRegister`](circuit#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. | @@ -392,7 +487,7 @@ where the only change is that a `uint8_t conditional_key` entry has replaced `_B | 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. | +| 1 | The instruction has its `.condition` field set to a 2-tuple of either a [`Clbit`](circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") or a [`ClassicalRegister`](circuit#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. | @@ -407,8 +502,6 @@ A new type code `x` is added that defines an EXPRESSION parameter. 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 @@ -473,7 +566,7 @@ New type key character is added to the [SCHEDULE\_BLOCK\_OPERANDS](#qpy-schedule 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). +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`](circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") or [`Clbit`](circuit#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). @@ -918,7 +1011,6 @@ struct { uint64_t metadata_size; uint32_t num_registers; uint64_t num_instructions; - uint64_t num_custom_gates; } ``` @@ -928,7 +1020,7 @@ This is immediately followed by `name_size` bytes of utf8 data for the name of t ### Version 1 - + #### HEADER @@ -943,7 +1035,6 @@ struct { uint64_t metadata_size; uint32_t num_registers; uint64_t num_instructions; - uint64_t num_custom_gates; } ``` @@ -1090,7 +1181,7 @@ which is immediately followed by `name_size` utf8 bytes representing the paramet - + #### PARAMETER\_EXPR @@ -1135,11 +1226,11 @@ this matches the internal C representation of Python’s complex type. [\[3\]](# [https://tools.ietf.org/html/rfc1700](https://tools.ietf.org/html/rfc1700) -\[2] ([1](#id4),[2](#id6)) +\[2] ([1](#id3),[2](#id5)) [https://numpy.org/doc/stable/reference/generated/numpy.lib.format.html](https://numpy.org/doc/stable/reference/generated/numpy.lib.format.html) -\[[3](#id8)] +\[[3](#id7)] [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/quantum_info.mdx b/docs/api/qiskit/quantum_info.mdx index b6e33579a8b..0d280ba4270 100644 --- a/docs/api/qiskit/quantum_info.mdx +++ b/docs/api/qiskit/quantum_info.mdx @@ -58,7 +58,7 @@ python_api_name: qiskit.quantum_info ### average\_gate\_fidelity - + Return the average gate fidelity of a noisy quantum channel. The average gate fidelity $F_{\text{ave}}$ is given by @@ -98,7 +98,7 @@ $$ ### process\_fidelity - + 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 @@ -145,7 +145,7 @@ $$ ### gate\_error - + Return the gate error of a noisy quantum channel. The gate error $E$ is given by the average gate infidelity @@ -180,7 +180,7 @@ $$ ### diamond\_norm - + 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]. @@ -218,7 +218,7 @@ $$ ### state\_fidelity - + Return the state fidelity between two quantum states. The state fidelity $F$ for density matrix input states $\rho_1, \rho_2$ is given by @@ -252,7 +252,7 @@ $$ ### purity - + Calculate the purity of a quantum state. The purity of a density matrix $\rho$ is @@ -281,7 +281,7 @@ $$ ### concurrence - + 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 @@ -321,7 +321,7 @@ $$ ### entropy - + Calculate the von-Neumann entropy of a quantum state. The entropy $S$ is given by @@ -350,7 +350,7 @@ $$ ### entanglement\_of\_formation - + 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. @@ -376,7 +376,7 @@ $$ ### mutual\_information - + Calculate the mutual information of a bipartite state. The mutual information $I$ is given by: @@ -414,7 +414,7 @@ $$ ### partial\_trace - + 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. @@ -439,7 +439,7 @@ $$ ### schmidt\_decomposition - + Return the Schmidt Decomposition of a pure quantum state. For an arbitrary bipartite state: @@ -487,7 +487,7 @@ $$ ### shannon\_entropy - + 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 @@ -514,7 +514,7 @@ $$ ### commutator - + Compute commutator of a and b. $$ @@ -537,7 +537,7 @@ $$ ### anti\_commutator - + Compute anti-commutator of a and b. $$ @@ -560,7 +560,7 @@ $$ ### double\_commutator - + Compute symmetric double commutator of a, b and c. See also Equation (13.6.18) in \[1]. @@ -607,7 +607,7 @@ $$ ### random\_statevector - + Generator a random Statevector. The statevector is sampled from the uniform distribution. This is the measure induced by the Haar measure on unitary matrices. @@ -632,7 +632,7 @@ $$ ### random\_density\_matrix - + Generator a random DensityMatrix. **Parameters** @@ -657,7 +657,7 @@ $$ ### random\_unitary - + Return a random unitary Operator. The operator is sampled from the unitary Haar measure. @@ -678,7 +678,7 @@ $$ ### random\_hermitian - + Return a random hermitian Operator. The operator is sampled from Gaussian Unitary Ensemble. @@ -700,7 +700,7 @@ $$ ### random\_pauli - + Return a random Pauli. **Parameters** @@ -720,7 +720,7 @@ $$ ### random\_clifford - + Return a random Clifford operator. The Clifford is sampled using the method of Reference \[1]. @@ -745,7 +745,7 @@ $$ ### random\_quantum\_channel - + 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. @@ -772,7 +772,7 @@ $$ ### random\_cnotdihedral - + Return a random CNOTDihedral element. **Parameters** @@ -791,7 +791,7 @@ $$ ### random\_pauli\_list - + Return a random PauliList. **Parameters** @@ -814,7 +814,7 @@ $$ ### hellinger\_distance - + Computes the Hellinger distance between two counts distributions. **Parameters** @@ -837,7 +837,7 @@ $$ ### hellinger\_fidelity - + 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]. diff --git a/docs/api/qiskit/release-notes/1.0.mdx b/docs/api/qiskit/release-notes/1.0.mdx index d01a1132edc..224f3f986c0 100644 --- a/docs/api/qiskit/release-notes/1.0.mdx +++ b/docs/api/qiskit/release-notes/1.0.mdx @@ -19,27 +19,27 @@ Qiskit 1.0.2 is a minor bugfix release for the 1.0 series. ### Bug Fixes -* Fixed an issue with [`convert_to_target()`](/api/qiskit/qiskit.providers.convert_to_target "qiskit.providers.convert_to_target") where the converter would incorrectly ignore control flow instructions if they were specified in the `BackendConfiguration.supported_instructions` attribute, which is the typical location that control flow instructions are specified in a [`BackendConfiguration`](/api/qiskit/qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") object. Fixed [#11872](https://github.com/Qiskit/qiskit/issues/11872). +* Fixed an issue with [`convert_to_target()`](/api/qiskit/1.0/qiskit.providers.convert_to_target "qiskit.providers.convert_to_target") where the converter would incorrectly ignore control flow instructions if they were specified in the `BackendConfiguration.supported_instructions` attribute, which is the typical location that control flow instructions are specified in a [`BackendConfiguration`](/api/qiskit/1.0/qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") object. Fixed [#11872](https://github.com/Qiskit/qiskit/issues/11872). -* Calling [`EquivalenceLibrary.set_entry()`](/api/qiskit/qiskit.circuit.EquivalenceLibrary#set_entry "qiskit.circuit.EquivalenceLibrary.set_entry") will now correctly update the internal graph object of the library. Previously, the metadata would be updated, but the graph structure would be unaltered, meaning that users like [`BasisTranslator`](/api/qiskit/qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator") would still use the old rules. Fixed [#11958](https://github.com/Qiskit/qiskit/issues/11958). +* Calling [`EquivalenceLibrary.set_entry()`](/api/qiskit/1.0/qiskit.circuit.EquivalenceLibrary#set_entry "qiskit.circuit.EquivalenceLibrary.set_entry") will now correctly update the internal graph object of the library. Previously, the metadata would be updated, but the graph structure would be unaltered, meaning that users like [`BasisTranslator`](/api/qiskit/1.0/qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator") would still use the old rules. Fixed [#11958](https://github.com/Qiskit/qiskit/issues/11958). -* The [`EvolvedOperatorAnsatz`](/api/qiskit/qiskit.circuit.library.EvolvedOperatorAnsatz "qiskit.circuit.library.EvolvedOperatorAnsatz") now correctly handles the case where the `operators` argument is an empty list. Previously, this would result in an error. +* The [`EvolvedOperatorAnsatz`](/api/qiskit/1.0/qiskit.circuit.library.EvolvedOperatorAnsatz "qiskit.circuit.library.EvolvedOperatorAnsatz") now correctly handles the case where the `operators` argument is an empty list. Previously, this would result in an error. -* Fixed a consistency issue with [`EvolvedOperatorAnsatz`](/api/qiskit/qiskit.circuit.library.EvolvedOperatorAnsatz "qiskit.circuit.library.EvolvedOperatorAnsatz") instances with zero qubits. Previously, such instances would contain a single [`QuantumRegister`](/api/qiskit/qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") in [`qregs`](/api/qiskit/qiskit.circuit.library.EvolvedOperatorAnsatz#qregs "qiskit.circuit.library.EvolvedOperatorAnsatz.qregs") with zero qubits, but now no registers are created. This behavior aligns more consistently with its superclass [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). +* Fixed a consistency issue with [`EvolvedOperatorAnsatz`](/api/qiskit/1.0/qiskit.circuit.library.EvolvedOperatorAnsatz "qiskit.circuit.library.EvolvedOperatorAnsatz") instances with zero qubits. Previously, such instances would contain a single [`QuantumRegister`](/api/qiskit/1.0/qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") in [`qregs`](/api/qiskit/1.0/qiskit.circuit.library.EvolvedOperatorAnsatz#qregs "qiskit.circuit.library.EvolvedOperatorAnsatz.qregs") with zero qubits, but now no registers are created. This behavior aligns more consistently with its superclass [`QuantumCircuit`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). -* Fixed a crash in [`convert_to_target()`](/api/qiskit/qiskit.providers.convert_to_target "qiskit.providers.convert_to_target") which would occur when qubit properties (either T1, T2 or frequency) were missing. The missing property values in [`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") are now filled with `None`. +* Fixed a crash in [`convert_to_target()`](/api/qiskit/1.0/qiskit.providers.convert_to_target "qiskit.providers.convert_to_target") which would occur when qubit properties (either T1, T2 or frequency) were missing. The missing property values in [`QubitProperties`](/api/qiskit/1.0/qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") are now filled with `None`. -* Fixed a performance issue in the [`qpy.load()`](/api/qiskit/qpy#qiskit.qpy.load "qiskit.qpy.load") function when deserializing QPY payloads with large numbers of qubits or clbits in a circuit. +* Fixed a performance issue in the [`qpy.load()`](/api/qiskit/1.0/qpy#qiskit.qpy.load "qiskit.qpy.load") function when deserializing QPY payloads with large numbers of qubits or clbits in a circuit. * Fixed a bug where `EstimatorPub.coerce()` and `SamplerPub.coerce()` improperly handled a parameter of type `BindingsArray`. Previously a `ValueError` exception was falsely raised. -* The preset pass managers used by [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") will no longer fail on circuits with control flow when no hardware target or basis-gate set is specified. They will now treat such abstract targets as permitting all control-flow operations. Fixed [#11906](https://github.com/Qiskit/qiskit/issues/11906). +* The preset pass managers used by [`transpile()`](/api/qiskit/1.0/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") will no longer fail on circuits with control flow when no hardware target or basis-gate set is specified. They will now treat such abstract targets as permitting all control-flow operations. Fixed [#11906](https://github.com/Qiskit/qiskit/issues/11906). * Fixed `coerce()` so that it returns a 0-d array when the input is a single, unnested observable. Previously, it erroneously upgraded to a single dimension, with shape `(1,)`. -* [`Parameter`](/api/qiskit/qiskit.circuit.Parameter "qiskit.circuit.Parameter") was updated so that instances that compare equal always have the same hash. Previously, only the [`Parameter.uuid`](/api/qiskit/qiskit.circuit.Parameter#uuid "qiskit.circuit.Parameter.uuid") was compared, so [`Parameter`](/api/qiskit/qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances with different names could compare equal if they had been constructed using a common value for the `uuid` parameter (which is usually not passed explicitly). +* [`Parameter`](/api/qiskit/1.0/qiskit.circuit.Parameter "qiskit.circuit.Parameter") was updated so that instances that compare equal always have the same hash. Previously, only the [`Parameter.uuid`](/api/qiskit/1.0/qiskit.circuit.Parameter#uuid "qiskit.circuit.Parameter.uuid") was compared, so [`Parameter`](/api/qiskit/1.0/qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances with different names could compare equal if they had been constructed using a common value for the `uuid` parameter (which is usually not passed explicitly). -* Fixed bug in [`QuantumCircuit.draw()`](/api/qiskit/qiskit.circuit.QuantumCircuit#draw "qiskit.circuit.QuantumCircuit.draw") that was causing custom style dictionaries for the Matplotlib drawer to be modified upon execution. +* Fixed bug in [`QuantumCircuit.draw()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#draw "qiskit.circuit.QuantumCircuit.draw") that was causing custom style dictionaries for the Matplotlib drawer to be modified upon execution. @@ -61,11 +61,11 @@ Qiskit 1.0.1 is a patch release fixing a small number of bugs identified in the ### Bug Fixes -* Fixed a bug in the conversion of custom pulse instructions to the legacy [`qiskit.qobj`](/api/qiskit/qobj#module-qiskit.qobj "qiskit.qobj") format. The bug was introduced in Qiskit 1.0.0 and caused conversion of instructions with custom pulse shapes to raise an error. After the fix, the conversion is carried out correctly, and the custom pulse is converted to a `pulse.Waveform` as it should. Fixed [#11828](https://github.com/Qiskit/qiskit/issues/11828). +* Fixed a bug in the conversion of custom pulse instructions to the legacy [`qiskit.qobj`](/api/qiskit/1.0/qobj#module-qiskit.qobj "qiskit.qobj") format. The bug was introduced in Qiskit 1.0.0 and caused conversion of instructions with custom pulse shapes to raise an error. After the fix, the conversion is carried out correctly, and the custom pulse is converted to a `pulse.Waveform` as it should. Fixed [#11828](https://github.com/Qiskit/qiskit/issues/11828). -* Fixed an issue in the [`InverseCancellation`](/api/qiskit/qiskit.transpiler.passes.InverseCancellation "qiskit.transpiler.passes.InverseCancellation") transpiler pass where in some cases it would incorrectly cancel a self-inverse parameterized gate even if the parameter value didn’t match. Fixed [#11815](https://github.com/Qiskit/qiskit/issues/11815). +* Fixed an issue in the [`InverseCancellation`](/api/qiskit/1.0/qiskit.transpiler.passes.InverseCancellation "qiskit.transpiler.passes.InverseCancellation") transpiler pass where in some cases it would incorrectly cancel a self-inverse parameterized gate even if the parameter value didn’t match. Fixed [#11815](https://github.com/Qiskit/qiskit/issues/11815). -* [`BasePassManager.run()`](/api/qiskit/qiskit.passmanager.BasePassManager#run "qiskit.passmanager.BasePassManager.run") will no longer leak the previous [`PropertySet`](/api/qiskit/qiskit.passmanager.PropertySet "qiskit.passmanager.PropertySet") into new workflows when called more than once. Previously, the same [`PropertySet`](/api/qiskit/qiskit.passmanager.PropertySet "qiskit.passmanager.PropertySet") as before would be used to initialize follow-on runs, which could mean that invalid property information was being given to tasks. The behavior now matches that of Qiskit 0.44. Fixed [#11784](https://github.com/Qiskit/qiskit/issues/11784). +* [`BasePassManager.run()`](/api/qiskit/1.0/qiskit.passmanager.BasePassManager#run "qiskit.passmanager.BasePassManager.run") will no longer leak the previous [`PropertySet`](/api/qiskit/1.0/qiskit.passmanager.PropertySet "qiskit.passmanager.PropertySet") into new workflows when called more than once. Previously, the same [`PropertySet`](/api/qiskit/1.0/qiskit.passmanager.PropertySet "qiskit.passmanager.PropertySet") as before would be used to initialize follow-on runs, which could mean that invalid property information was being given to tasks. The behavior now matches that of Qiskit 0.44. Fixed [#11784](https://github.com/Qiskit/qiskit/issues/11784). * A bug has been fixed in `convert_durations_to_dt()` where the function assumed its inputs were all in seconds, rather than reading the actual unit. This could lead to wrong orders of magnitude in the reported circuit durations. @@ -91,9 +91,9 @@ Also of key importance in this release is the change in packaging. Since the Qis As with all of our major releases, Qiskit 1.0.0 also has a plethora of new features, the highlights for this release are: -> * The [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") class’s internal [`data`](/api/qiskit/qiskit.circuit.QuantumCircuit#data "qiskit.circuit.QuantumCircuit.data") structure has been rewritten in Rust to greatly improve the memory efficiency of the [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") objects by caching the arguments of the instructions. -> * A new version of the primitives interface definition in [`qiskit.primitives`](/api/qiskit/primitives#module-qiskit.primitives "qiskit.primitives") with the [`BaseSamplerV2`](/api/qiskit/qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") and [`BaseEstimatorV2`](/api/qiskit/qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") abstract classes. This new version of the interface adds support for performing vectorized calls to the primitive so that sweeps over parameter value sets and observables can be efficiently specified. -> * A new experimental native OpenQASM 3 parser [`qiskit.qasm3.loads_experimental()`](/api/qiskit/qasm3#qiskit.qasm3.loads_experimental "qiskit.qasm3.loads_experimental") and [`qiskit.qasm3.load_experimental()`](/api/qiskit/qasm3#qiskit.qasm3.load_experimental "qiskit.qasm3.load_experimental"). This new parser is still under development and still has several limitations and is still experimental. However, for where it is usable, the new parser is significantly faster and has better diagnostic error message that allows to debug where an OpenQASM 3 program is invalid. This new parser is written in Rust and based on a newly developed Rust library for parsing OpenQASM3 which can be found here: [https://github.com/Qiskit/openqasm3\_parser](https://github.com/Qiskit/openqasm3_parser) +> * The [`QuantumCircuit`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") class’s internal [`data`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#data "qiskit.circuit.QuantumCircuit.data") structure has been rewritten in Rust to greatly improve the memory efficiency of the [`QuantumCircuit`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") objects by caching the arguments of the instructions. +> * A new version of the primitives interface definition in [`qiskit.primitives`](/api/qiskit/1.0/primitives#module-qiskit.primitives "qiskit.primitives") with the [`BaseSamplerV2`](/api/qiskit/1.0/qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") and [`BaseEstimatorV2`](/api/qiskit/1.0/qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") abstract classes. This new version of the interface adds support for performing vectorized calls to the primitive so that sweeps over parameter value sets and observables can be efficiently specified. +> * A new experimental native OpenQASM 3 parser [`qiskit.qasm3.loads_experimental()`](/api/qiskit/1.0/qasm3#qiskit.qasm3.loads_experimental "qiskit.qasm3.loads_experimental") and [`qiskit.qasm3.load_experimental()`](/api/qiskit/1.0/qasm3#qiskit.qasm3.load_experimental "qiskit.qasm3.load_experimental"). This new parser is still under development and still has several limitations and is still experimental. However, for where it is usable, the new parser is significantly faster and has better diagnostic error message that allows to debug where an OpenQASM 3 program is invalid. This new parser is written in Rust and based on a newly developed Rust library for parsing OpenQASM3 which can be found here: [https://github.com/Qiskit/openqasm3\_parser](https://github.com/Qiskit/openqasm3_parser) Finally, the Qiskit 1.0.0 release was an opportunity to clean up some technical debt accumulated over the past 7 years of development. You’ll notice that the Qiskit 1.0.0 release is virtually free of `DeprecationWarning`s being emitted, and, at the same time, the upgrade section of the 1.0.0 release notes is longer than usual. These are direct consequences of the technical debt cleanup. To help with the migration from 0.46.x to 1.0.0, besides the release notes, we have also published a dedicated migration guide which can be found here: @@ -105,27 +105,27 @@ This guide is meant to complement the release notes and have a targeted advice f ### Circuits Features -* Added a new argument, `annotated`, to the methods [`QuantumCircuit.inverse()`](/api/qiskit/qiskit.circuit.QuantumCircuit#inverse "qiskit.circuit.QuantumCircuit.inverse"), [`circuit.Instruction.inverse()`](/api/qiskit/qiskit.circuit.Instruction#inverse "qiskit.circuit.Instruction.inverse") and `.inverse()` methods of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "qiskit.circuit.Instruction") subclasses (such as [`SwapGate`](/api/qiskit/qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate") or [`SGate`](/api/qiskit/qiskit.circuit.library.SGate "qiskit.circuit.library.SGate")) to optionally return an [`AnnotatedOperation`](/api/qiskit/qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). The default value of `annotated` is `False` and corresponds to the pre-existing behavior of the method. Furthermore, for standard gates with an explicitly defined `inverse` method, the argument `annotated` has no effect, for example, both: +* Added a new argument, `annotated`, to the methods [`QuantumCircuit.inverse()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#inverse "qiskit.circuit.QuantumCircuit.inverse"), [`circuit.Instruction.inverse()`](/api/qiskit/1.0/qiskit.circuit.Instruction#inverse "qiskit.circuit.Instruction.inverse") and `.inverse()` methods of [`Instruction`](/api/qiskit/1.0/qiskit.circuit.Instruction "qiskit.circuit.Instruction") subclasses (such as [`SwapGate`](/api/qiskit/1.0/qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate") or [`SGate`](/api/qiskit/1.0/qiskit.circuit.library.SGate "qiskit.circuit.library.SGate")) to optionally return an [`AnnotatedOperation`](/api/qiskit/1.0/qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). The default value of `annotated` is `False` and corresponds to the pre-existing behavior of the method. Furthermore, for standard gates with an explicitly defined `inverse` method, the argument `annotated` has no effect, for example, both: ```python SwapGate().inverse(annotated=False) SwapGate().inverse(annotated=True) ``` - return a [`SwapGate`](/api/qiskit/qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate"), and both: + return a [`SwapGate`](/api/qiskit/1.0/qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate"), and both: ```python SGate().inverse(annotated=False) SGate().inverse(annotated=True) ``` - return an [`SdgGate`](/api/qiskit/qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate"). The difference manifests for custom instructions without an explicitly defined inverse. With `annotated=False`, the method returns a fresh instruction with the recursively inverted definition, just as before. While `annotated=True` returns an [`AnnotatedOperation`](/api/qiskit/qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") that represents the instruction modified with the [`InverseModifier`](/api/qiskit/qiskit.circuit.InverseModifier "qiskit.circuit.InverseModifier"). + return an [`SdgGate`](/api/qiskit/1.0/qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate"). The difference manifests for custom instructions without an explicitly defined inverse. With `annotated=False`, the method returns a fresh instruction with the recursively inverted definition, just as before. While `annotated=True` returns an [`AnnotatedOperation`](/api/qiskit/1.0/qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") that represents the instruction modified with the [`InverseModifier`](/api/qiskit/1.0/qiskit.circuit.InverseModifier "qiskit.circuit.InverseModifier"). -* Added a commutation library to the [`CommutationChecker`](/api/qiskit/qiskit.circuit.CommutationChecker "qiskit.circuit.CommutationChecker"). This library stores all the commutation relations of unparameterizable standard gates into a dictionary that allows for efficient lookup at runtime. This speeds up the execution of the [`CommutationChecker`](/api/qiskit/qiskit.circuit.CommutationChecker "qiskit.circuit.CommutationChecker") class and, by extension, the [`CommutationAnalysis`](/api/qiskit/qiskit.transpiler.passes.CommutationAnalysis "qiskit.transpiler.passes.CommutationAnalysis") transpiler pass, as instead of computing whether two unparameterizable standard gates commute it just has to look it up from the library. +* Added a commutation library to the [`CommutationChecker`](/api/qiskit/1.0/qiskit.circuit.CommutationChecker "qiskit.circuit.CommutationChecker"). This library stores all the commutation relations of unparameterizable standard gates into a dictionary that allows for efficient lookup at runtime. This speeds up the execution of the [`CommutationChecker`](/api/qiskit/1.0/qiskit.circuit.CommutationChecker "qiskit.circuit.CommutationChecker") class and, by extension, the [`CommutationAnalysis`](/api/qiskit/1.0/qiskit.transpiler.passes.CommutationAnalysis "qiskit.transpiler.passes.CommutationAnalysis") transpiler pass, as instead of computing whether two unparameterizable standard gates commute it just has to look it up from the library. - Additionally, the [`CommutationChecker`](/api/qiskit/qiskit.circuit.CommutationChecker "qiskit.circuit.CommutationChecker") was refactored and now has an upper limit set on the number of cached commutation relations that are not in the commutation library. This addressed: [#8020](https://github.com/Qiskit/qiskit/issues/8020) and [#7101](https://github.com/Qiskit/qiskit/issues/7101) + Additionally, the [`CommutationChecker`](/api/qiskit/1.0/qiskit.circuit.CommutationChecker "qiskit.circuit.CommutationChecker") was refactored and now has an upper limit set on the number of cached commutation relations that are not in the commutation library. This addressed: [#8020](https://github.com/Qiskit/qiskit/issues/8020) and [#7101](https://github.com/Qiskit/qiskit/issues/7101) -* [`QuantumCircuit.assign_parameters()`](/api/qiskit/qiskit.circuit.QuantumCircuit#assign_parameters "qiskit.circuit.QuantumCircuit.assign_parameters") now accepts string keys in the mapping form of input. These names are used to look up the corresponding [`Parameter`](/api/qiskit/qiskit.circuit.Parameter "qiskit.circuit.Parameter") instance using [`get_parameter()`](/api/qiskit/qiskit.circuit.QuantumCircuit#get_parameter "qiskit.circuit.QuantumCircuit.get_parameter"). This lets you do: +* [`QuantumCircuit.assign_parameters()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#assign_parameters "qiskit.circuit.QuantumCircuit.assign_parameters") now accepts string keys in the mapping form of input. These names are used to look up the corresponding [`Parameter`](/api/qiskit/1.0/qiskit.circuit.Parameter "qiskit.circuit.Parameter") instance using [`get_parameter()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#get_parameter "qiskit.circuit.QuantumCircuit.get_parameter"). This lets you do: ```python from qiskit.circuit import QuantumCircuit, Parameter @@ -137,35 +137,35 @@ This guide is meant to complement the release notes and have a targeted advice f qc.assign_parameters({"a": 1}) == qc.assign_parameters({a: 1}) ``` -* [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") has two new methods, [`get_parameter()`](/api/qiskit/qiskit.circuit.QuantumCircuit#get_parameter "qiskit.circuit.QuantumCircuit.get_parameter") and [`has_parameter()`](/api/qiskit/qiskit.circuit.QuantumCircuit#has_parameter "qiskit.circuit.QuantumCircuit.has_parameter"), which respectively retrieve a [`Parameter`](/api/qiskit/qiskit.circuit.Parameter "qiskit.circuit.Parameter") instance used in the circuit by name, and return a boolean of whether a parameter with a matching name (or the exact instance given) are used in the circuit. +* [`QuantumCircuit`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") has two new methods, [`get_parameter()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#get_parameter "qiskit.circuit.QuantumCircuit.get_parameter") and [`has_parameter()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#has_parameter "qiskit.circuit.QuantumCircuit.has_parameter"), which respectively retrieve a [`Parameter`](/api/qiskit/1.0/qiskit.circuit.Parameter "qiskit.circuit.Parameter") instance used in the circuit by name, and return a boolean of whether a parameter with a matching name (or the exact instance given) are used in the circuit. -* A [`uuid`](/api/qiskit/qiskit.circuit.Parameter#uuid "qiskit.circuit.Parameter.uuid") property was added to the [`qiskit.circuit.Parameter`](/api/qiskit/qiskit.circuit.Parameter "qiskit.circuit.Parameter") class. In advanced use cases, this property can be used for creating [`qiskit.circuit.Parameter`](/api/qiskit/qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances that compare equal to each other. +* A [`uuid`](/api/qiskit/1.0/qiskit.circuit.Parameter#uuid "qiskit.circuit.Parameter.uuid") property was added to the [`qiskit.circuit.Parameter`](/api/qiskit/1.0/qiskit.circuit.Parameter "qiskit.circuit.Parameter") class. In advanced use cases, this property can be used for creating [`qiskit.circuit.Parameter`](/api/qiskit/1.0/qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances that compare equal to each other. -* Added a new method, [`ParameterExpression.numeric()`](/api/qiskit/qiskit.circuit.ParameterExpression#numeric "qiskit.circuit.ParameterExpression.numeric"), which converts a fully bound parameter expression into the most restrictive built-in Python numeric type that accurately describes the result of the symbolic evaluation. For example, a symbolic integer will become an [`int`](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"), while a symbolic real number will become a [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") and a complex number will become a [`complex`](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)"). This method includes several workarounds for peculiarities of the evaluation contexts of `symengine`, which can sometimes lead to spurious results when calling [`complex`](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") or [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") on an expression directly. +* Added a new method, [`ParameterExpression.numeric()`](/api/qiskit/1.0/qiskit.circuit.ParameterExpression#numeric "qiskit.circuit.ParameterExpression.numeric"), which converts a fully bound parameter expression into the most restrictive built-in Python numeric type that accurately describes the result of the symbolic evaluation. For example, a symbolic integer will become an [`int`](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"), while a symbolic real number will become a [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") and a complex number will become a [`complex`](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)"). This method includes several workarounds for peculiarities of the evaluation contexts of `symengine`, which can sometimes lead to spurious results when calling [`complex`](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") or [`float`](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") on an expression directly. ### Primitives Features -* Version 2 of the primitives is introduced via a new base class for both the sampler and the estimator, along with new types for their inputs and outputs. The emphasis of this new version is on performing vectorized calls to the primitive `run()` methods, so that sweeps over parameter value sets and observables can be efficiently specified. See [`StatevectorSampler`](/api/qiskit/qiskit.primitives.StatevectorSampler "qiskit.primitives.StatevectorSampler") and [`StatevectorEstimator`](/api/qiskit/qiskit.primitives.StatevectorEstimator "qiskit.primitives.StatevectorEstimator") for reference implementations of the V2 primitives. +* Version 2 of the primitives is introduced via a new base class for both the sampler and the estimator, along with new types for their inputs and outputs. The emphasis of this new version is on performing vectorized calls to the primitive `run()` methods, so that sweeps over parameter value sets and observables can be efficiently specified. See [`StatevectorSampler`](/api/qiskit/1.0/qiskit.primitives.StatevectorSampler "qiskit.primitives.StatevectorSampler") and [`StatevectorEstimator`](/api/qiskit/1.0/qiskit.primitives.StatevectorEstimator "qiskit.primitives.StatevectorEstimator") for reference implementations of the V2 primitives. - Moreover, the estimator has gained a `precision` argument in the [`run()`](/api/qiskit/qiskit.primitives.BaseEstimatorV2#run "qiskit.primitives.BaseEstimatorV2.run") method that specifies the targeted precision of the expectation value estimates. Analogously, the sampler has moved `shots` out of the options and into the arguments of the [`run()`](/api/qiskit/qiskit.primitives.BaseSamplerV2#run "qiskit.primitives.BaseSamplerV2.run") method. The sampler has also been changed to return the outputs (e.g. bitstrings) from every shot, rather than providing a [`Counts`](/api/qiskit/qiskit.result.Counts "qiskit.result.Counts")-like return, and also to store data from separate [`ClassicalRegister`](/api/qiskit/qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")s . This enables derived classes to implement sampler support for circuits with classical control flow. + Moreover, the estimator has gained a `precision` argument in the [`run()`](/api/qiskit/1.0/qiskit.primitives.BaseEstimatorV2#run "qiskit.primitives.BaseEstimatorV2.run") method that specifies the targeted precision of the expectation value estimates. Analogously, the sampler has moved `shots` out of the options and into the arguments of the [`run()`](/api/qiskit/1.0/qiskit.primitives.BaseSamplerV2#run "qiskit.primitives.BaseSamplerV2.run") method. The sampler has also been changed to return the outputs (e.g. bitstrings) from every shot, rather than providing a [`Counts`](/api/qiskit/1.0/qiskit.result.Counts "qiskit.result.Counts")-like return, and also to store data from separate [`ClassicalRegister`](/api/qiskit/1.0/qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")s . This enables derived classes to implement sampler support for circuits with classical control flow. The primitive V2 base classes are: - * [`BaseSamplerV2`](/api/qiskit/qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") - * [`BaseEstimatorV2`](/api/qiskit/qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") + * [`BaseSamplerV2`](/api/qiskit/1.0/qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") + * [`BaseEstimatorV2`](/api/qiskit/1.0/qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") The new types which are used for inputs and outputs are: * `SamplerPubLike`: primitive unified bloc (PUB) of sampler inputs; a union type of allowed inputs to a sampler * `EstimatorPubLike`: Primitive unified bloc (PUB) of estimator inputs; a union type of allowed inputs to an estimator - * [`PubResult`](/api/qiskit/qiskit.primitives.PubResult "qiskit.primitives.PubResult"): the data and metadata resulting from a single PUB’s execution - * [`DataBin`](/api/qiskit/qiskit.primitives.DataBin "qiskit.primitives.DataBin"): A namespace to hold data from a single PUB’s execution - * [`BitArray`](/api/qiskit/qiskit.primitives.BitArray "qiskit.primitives.BitArray"): an array-valued collection of bit values in a dense format - * [`PrimitiveResult`](/api/qiskit/qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult"): an iterable of [`PubResult`](/api/qiskit/qiskit.primitives.PubResult "qiskit.primitives.PubResult")s along with metadata + * [`PubResult`](/api/qiskit/1.0/qiskit.primitives.PubResult "qiskit.primitives.PubResult"): the data and metadata resulting from a single PUB’s execution + * [`DataBin`](/api/qiskit/1.0/qiskit.primitives.DataBin "qiskit.primitives.DataBin"): A namespace to hold data from a single PUB’s execution + * [`BitArray`](/api/qiskit/1.0/qiskit.primitives.BitArray "qiskit.primitives.BitArray"): an array-valued collection of bit values in a dense format + * [`PrimitiveResult`](/api/qiskit/1.0/qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult"): an iterable of [`PubResult`](/api/qiskit/1.0/qiskit.primitives.PubResult "qiskit.primitives.PubResult")s along with metadata -* The reference implementation [`StatevectorEstimator`](/api/qiskit/qiskit.primitives.StatevectorEstimator "qiskit.primitives.StatevectorEstimator") of [`BaseEstimatorV2`](/api/qiskit/qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") was added. As seen in the example below, this estimator (and all V2 estimators) supports providing arrays of observables and/or arrays of parameter value sets that are attached to particular circuits. +* The reference implementation [`StatevectorEstimator`](/api/qiskit/1.0/qiskit.primitives.StatevectorEstimator "qiskit.primitives.StatevectorEstimator") of [`BaseEstimatorV2`](/api/qiskit/1.0/qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") was added. As seen in the example below, this estimator (and all V2 estimators) supports providing arrays of observables and/or arrays of parameter value sets that are attached to particular circuits. Each tuple of `(circuit, observables, parameter values, precision)`, called an estimator primitive unified bloc (PUB), produces its own array-based result. The `run()` method can be given many pubs at once. @@ -228,7 +228,7 @@ This guide is meant to complement the release notes and have a targeted advice f plt.legend() ``` -* The reference implementation [`StatevectorSampler`](/api/qiskit/qiskit.primitives.StatevectorSampler "qiskit.primitives.StatevectorSampler") of [`BaseSamplerV2`](/api/qiskit/qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") was added. As seen in the example below, this sampler (and all V2 samplers) supports providing arrays of parameter value sets to bind against a single circuit. +* The reference implementation [`StatevectorSampler`](/api/qiskit/1.0/qiskit.primitives.StatevectorSampler "qiskit.primitives.StatevectorSampler") of [`BaseSamplerV2`](/api/qiskit/1.0/qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") was added. As seen in the example below, this sampler (and all V2 samplers) supports providing arrays of parameter value sets to bind against a single circuit. Each tuple of `(circuit, parameter values, shots)`, called a sampler primitive unified bloc (PUB), produces its own array-based result. The `run()` method can be given many pubs at once. @@ -302,7 +302,7 @@ This guide is meant to complement the release notes and have a targeted advice f ### Providers Features -* Added a new class, [`GenericBackendV2`](/api/qiskit/qiskit.providers.fake_provider.GenericBackendV2 "qiskit.providers.fake_provider.GenericBackendV2"), to the [`qiskit.providers.fake_provider`](/api/qiskit/providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider") module. This class is configurable, and builds a [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "qiskit.providers.BackendV2") backend instance that can be run locally (in the spirit of fake backends). Users can configure the number of qubits, basis gates, coupling map, ability to run dynamic circuits (control flow instructions), instruction calibrations and measurement timestep of the backend without having to deal with manual target construction. Qubit and gate properties (duration, error) are generated by randomly sampling from default ranges. The seed for this random generation can be fixed to ensure the reproducibility of the backend output. It’s important to note that 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`](/api/qiskit/qiskit.transpiler.Target "qiskit.transpiler.Target") object to use for transpilation. +* Added a new class, [`GenericBackendV2`](/api/qiskit/1.0/qiskit.providers.fake_provider.GenericBackendV2 "qiskit.providers.fake_provider.GenericBackendV2"), to the [`qiskit.providers.fake_provider`](/api/qiskit/1.0/providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider") module. This class is configurable, and builds a [`BackendV2`](/api/qiskit/1.0/qiskit.providers.BackendV2 "qiskit.providers.BackendV2") backend instance that can be run locally (in the spirit of fake backends). Users can configure the number of qubits, basis gates, coupling map, ability to run dynamic circuits (control flow instructions), instruction calibrations and measurement timestep of the backend without having to deal with manual target construction. Qubit and gate properties (duration, error) are generated by randomly sampling from default ranges. The seed for this random generation can be fixed to ensure the reproducibility of the backend output. It’s important to note that 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`](/api/qiskit/1.0/qiskit.transpiler.Target "qiskit.transpiler.Target") object to use for transpilation. Example usage 1: @@ -359,17 +359,17 @@ This guide is meant to complement the release notes and have a targeted advice f The noise properties generated by these class do not mimic any concrete quantum device, and should not be used to measure any concrete behaviors. They are “reasonable defaults” that can be used to test backend-interfacing functionality not tied specific noise values of real quantum systems. For a more accurate simulation of existing devices, you can manually build a noise model from the real backend using the functionality offered in [`qiskit_aer`](https://qiskit.github.io/qiskit-aer/apidocs/aer_provider.html#module-qiskit_aer "(in Qiskit Aer v0.14.0)"). -* The [`qiskit.providers.fake_provider`](/api/qiskit/providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider") module now includes a series of generic fake backends following the [`BackendV1`](/api/qiskit/qiskit.providers.BackendV1 "qiskit.providers.BackendV1") interface. They have been introduced as an alternative to the snapshot-based fake backends exposed in the deprecated `FakeProvider` (`FakeVigo`, `FakeTokyo`, etc). The list of new fake backends includes: +* The [`qiskit.providers.fake_provider`](/api/qiskit/1.0/providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider") module now includes a series of generic fake backends following the [`BackendV1`](/api/qiskit/1.0/qiskit.providers.BackendV1 "qiskit.providers.BackendV1") interface. They have been introduced as an alternative to the snapshot-based fake backends exposed in the deprecated `FakeProvider` (`FakeVigo`, `FakeTokyo`, etc). The list of new fake backends includes: > * Backends without pulse capabilities: > - > * [`Fake5QV1`](/api/qiskit/qiskit.providers.fake_provider.Fake5QV1 "qiskit.providers.fake_provider.Fake5QV1") - > * [`Fake20QV1`](/api/qiskit/qiskit.providers.fake_provider.Fake20QV1 "qiskit.providers.fake_provider.Fake20QV1") + > * [`Fake5QV1`](/api/qiskit/1.0/qiskit.providers.fake_provider.Fake5QV1 "qiskit.providers.fake_provider.Fake5QV1") + > * [`Fake20QV1`](/api/qiskit/1.0/qiskit.providers.fake_provider.Fake20QV1 "qiskit.providers.fake_provider.Fake20QV1") > * Backends with pulse capabilities: > - > * [`Fake7QPulseV1`](/api/qiskit/qiskit.providers.fake_provider.Fake7QPulseV1 "qiskit.providers.fake_provider.Fake7QPulseV1") - > * [`Fake27QPulseV1`](/api/qiskit/qiskit.providers.fake_provider.Fake27QPulseV1 "qiskit.providers.fake_provider.Fake27QPulseV1") - > * [`Fake127QPulseV1`](/api/qiskit/qiskit.providers.fake_provider.Fake127QPulseV1 "qiskit.providers.fake_provider.Fake127QPulseV1") + > * [`Fake7QPulseV1`](/api/qiskit/1.0/qiskit.providers.fake_provider.Fake7QPulseV1 "qiskit.providers.fake_provider.Fake7QPulseV1") + > * [`Fake27QPulseV1`](/api/qiskit/1.0/qiskit.providers.fake_provider.Fake27QPulseV1 "qiskit.providers.fake_provider.Fake27QPulseV1") + > * [`Fake127QPulseV1`](/api/qiskit/1.0/qiskit.providers.fake_provider.Fake127QPulseV1 "qiskit.providers.fake_provider.Fake127QPulseV1") They can be imported following the pattern: `from qiskit.providers.fake_provider import Fake5QV1`. More details on the backend properties can be found on each backend’s API documentation. @@ -377,9 +377,9 @@ This guide is meant to complement the release notes and have a targeted advice f ### OpenQASM Features -* The [`qiskit.qasm3`](/api/qiskit/qasm3#module-qiskit.qasm3 "qiskit.qasm3") package now contains a built-in, Rust-based parser for reading OpenQASM 3 programs into [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")s, found at [`qiskit.qasm3.load_experimental()`](/api/qiskit/qasm3#qiskit.qasm3.load_experimental "qiskit.qasm3.load_experimental") and [`loads_experimental()`](/api/qiskit/qasm3#qiskit.qasm3.loads_experimental "qiskit.qasm3.loads_experimental"). These are typically several times faster than the existing, pure Python [`load()`](/api/qiskit/qasm3#qiskit.qasm3.load "qiskit.qasm3.load") and [`loads()`](/api/qiskit/qasm3#qiskit.qasm3.loads "qiskit.qasm3.loads") functions, which additionally require `qiskit-qasm3-import` to be installed. +* The [`qiskit.qasm3`](/api/qiskit/1.0/qasm3#module-qiskit.qasm3 "qiskit.qasm3") package now contains a built-in, Rust-based parser for reading OpenQASM 3 programs into [`QuantumCircuit`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")s, found at [`qiskit.qasm3.load_experimental()`](/api/qiskit/1.0/qasm3#qiskit.qasm3.load_experimental "qiskit.qasm3.load_experimental") and [`loads_experimental()`](/api/qiskit/1.0/qasm3#qiskit.qasm3.loads_experimental "qiskit.qasm3.loads_experimental"). These are typically several times faster than the existing, pure Python [`load()`](/api/qiskit/1.0/qasm3#qiskit.qasm3.load "qiskit.qasm3.load") and [`loads()`](/api/qiskit/1.0/qasm3#qiskit.qasm3.loads "qiskit.qasm3.loads") functions, which additionally require `qiskit-qasm3-import` to be installed. - For example, we can create a 20,000-instruction entangling [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"): + For example, we can create a 20,000-instruction entangling [`QuantumCircuit`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"): ```python import numpy as np @@ -391,13 +391,13 @@ This guide is meant to complement the release notes and have a targeted advice f oq3 = qiskit.qasm3.dumps(qc) ``` - The old [`qasm3.loads()`](/api/qiskit/qasm3#qiskit.qasm3.loads "qiskit.qasm3.loads") took about 7.3s to load the resulting OpenQASM 3 program, whereas [`qasm3.loads_experimental()`](/api/qiskit/qasm3#qiskit.qasm3.loads_experimental "qiskit.qasm3.loads_experimental") took under 300ms on a consumer Macbook Pro (i7, 2020)–a speedup of 25x! + The old [`qasm3.loads()`](/api/qiskit/1.0/qasm3#qiskit.qasm3.loads "qiskit.qasm3.loads") took about 7.3s to load the resulting OpenQASM 3 program, whereas [`qasm3.loads_experimental()`](/api/qiskit/1.0/qasm3#qiskit.qasm3.loads_experimental "qiskit.qasm3.loads_experimental") took under 300ms on a consumer Macbook Pro (i7, 2020)–a speedup of 25x! The supported feature set of the experimental parser is very limited in this preview version, but this will expand as both the Qiskit side and [the native Rust-based parser](https://github.com/Qiskit/openqasm3_parser) improve. One of our main goals with this new parser, alongside the huge speed improvements, is to provide top-quality error diagnostics. As with other parts of the parser, these are a work in progress, but you’ll start to see much higher quality error messages displayed when parsing invalid OpenQASM 3 programs with the experimental parser. -* The OpenQASM 3 exporter (see [`dump()`](/api/qiskit/qasm3#qiskit.qasm3.dump "qiskit.qasm3.dump") and [`dumps()`](/api/qiskit/qasm3#qiskit.qasm3.dumps "qiskit.qasm3.dumps") functions in [`qiskit.qasm3`](/api/qiskit/qasm3#module-qiskit.qasm3 "qiskit.qasm3")) now supports the stabilized syntax of the `switch` statement in OpenQASM 3 by default. The pre-certification syntax of the `switch` statement is still available by using the [`ExperimentalFeatures.SWITCH_CASE_V1`](/api/qiskit/qasm3#qiskit.qasm3.ExperimentalFeatures.SWITCH_CASE_V1 "qiskit.qasm3.ExperimentalFeatures.SWITCH_CASE_V1") flag in the `experimental` argument of the exporter. There is no feature flag required for the stabilized syntax, but if you are interfacing with other tooling that is not yet updated, you may need to pass the experimental flag. +* The OpenQASM 3 exporter (see [`dump()`](/api/qiskit/1.0/qasm3#qiskit.qasm3.dump "qiskit.qasm3.dump") and [`dumps()`](/api/qiskit/1.0/qasm3#qiskit.qasm3.dumps "qiskit.qasm3.dumps") functions in [`qiskit.qasm3`](/api/qiskit/1.0/qasm3#module-qiskit.qasm3 "qiskit.qasm3")) now supports the stabilized syntax of the `switch` statement in OpenQASM 3 by default. The pre-certification syntax of the `switch` statement is still available by using the [`ExperimentalFeatures.SWITCH_CASE_V1`](/api/qiskit/1.0/qasm3#qiskit.qasm3.ExperimentalFeatures.SWITCH_CASE_V1 "qiskit.qasm3.ExperimentalFeatures.SWITCH_CASE_V1") flag in the `experimental` argument of the exporter. There is no feature flag required for the stabilized syntax, but if you are interfacing with other tooling that is not yet updated, you may need to pass the experimental flag. The syntax of the stabilized form is slightly different with regards to terminating `break` statements (no longer required nor permitted), and multiple cases are now combined into a single `case` line, rather than using C-style fall-through. For more detail, see [the OpenQASM 3 documentation on the switch-case construct](https://openqasm.com/language/classical.html#the-switch-statement). @@ -405,15 +405,15 @@ This guide is meant to complement the release notes and have a targeted advice f ### QPY Features -* Added a new warning class, [`QPYLoadingDeprecatedFeatureWarning`](/api/qiskit/qpy#qiskit.qpy.QPYLoadingDeprecatedFeatureWarning "qiskit.qpy.QPYLoadingDeprecatedFeatureWarning"), to the QPY module. This class allows for deprecation warnings to surface even if the deprecated feature is accessed at a variable point in the call stack, as is the case for many QPY loading functions that are called recursively. +* Added a new warning class, [`QPYLoadingDeprecatedFeatureWarning`](/api/qiskit/1.0/qpy#qiskit.qpy.QPYLoadingDeprecatedFeatureWarning "qiskit.qpy.QPYLoadingDeprecatedFeatureWarning"), to the QPY module. This class allows for deprecation warnings to surface even if the deprecated feature is accessed at a variable point in the call stack, as is the case for many QPY loading functions that are called recursively. -* Added a new flag, `version`, to the [`qpy.dump()`](/api/qiskit/qpy#qiskit.qpy.dump "qiskit.qpy.dump") function. This allows [`qpy.dump()`](/api/qiskit/qpy#qiskit.qpy.dump "qiskit.qpy.dump") to optionally take an integer value for the [QPY Format](/api/qiskit/qpy#qpy-format) version to emit. This is useful if you need to generate a QPY file that will be loaded by an older version of Qiskit. However, the supported versions to emit are limited, only versions between the latest QPY version (which is the default), and the compatibility QPY version which is [Version 10](/api/qiskit/qpy#qpy-version-10) (which was introduced in Qiskit 0.45.0) can be used. The compatibility version will remain fixed for the entire 1.x.y major version release series. This does not change the backwards compatibility guarantees of the QPY format when calling [`qpy.load()`](/api/qiskit/qpy#qiskit.qpy.load "qiskit.qpy.load"), it just enables users to emit an older version of QPY to maintain compatibility and interoperability between the 0.x and 1.x release series. +* Added a new flag, `version`, to the [`qpy.dump()`](/api/qiskit/1.0/qpy#qiskit.qpy.dump "qiskit.qpy.dump") function. This allows [`qpy.dump()`](/api/qiskit/1.0/qpy#qiskit.qpy.dump "qiskit.qpy.dump") to optionally take an integer value for the [QPY Format](/api/qiskit/1.0/qpy#qpy-format) version to emit. This is useful if you need to generate a QPY file that will be loaded by an older version of Qiskit. However, the supported versions to emit are limited, only versions between the latest QPY version (which is the default), and the compatibility QPY version which is [Version 10](/api/qiskit/1.0/qpy#qpy-version-10) (which was introduced in Qiskit 0.45.0) can be used. The compatibility version will remain fixed for the entire 1.x.y major version release series. This does not change the backwards compatibility guarantees of the QPY format when calling [`qpy.load()`](/api/qiskit/1.0/qpy#qiskit.qpy.load "qiskit.qpy.load"), it just enables users to emit an older version of QPY to maintain compatibility and interoperability between the 0.x and 1.x release series. ### Quantum Information Features -* Added a [`qiskit.quantum_info.StabilizerState.from_stabilizer_list()`](/api/qiskit/qiskit.quantum_info.StabilizerState#from_stabilizer_list "qiskit.quantum_info.StabilizerState.from_stabilizer_list") method that generates a stabilizer state from a list of stabilizers: +* Added a [`qiskit.quantum_info.StabilizerState.from_stabilizer_list()`](/api/qiskit/1.0/qiskit.quantum_info.StabilizerState#from_stabilizer_list "qiskit.quantum_info.StabilizerState.from_stabilizer_list") method that generates a stabilizer state from a list of stabilizers: ```python from qiskit.quantum_info import StabilizerState @@ -422,27 +422,27 @@ This guide is meant to complement the release notes and have a targeted advice f stab = StabilizerState.from_stabilizer_list(stabilizer_list) ``` -* [`SparsePauliOp.from_operator()`](/api/qiskit/qiskit.quantum_info.SparsePauliOp#from_operator "qiskit.quantum_info.SparsePauliOp.from_operator") now uses an implementation of the “tensorized Pauli decomposition algorithm” presented in [Hatznko, Binkowski and Gupta (2023)](https://arxiv.org/abs/2310.13421). The method is now several orders of magnitude faster; for example, it is possible to decompose a random 10-qubit operator in around 250ms on a consumer Macbook Pro (Intel i7, 2020). +* [`SparsePauliOp.from_operator()`](/api/qiskit/1.0/qiskit.quantum_info.SparsePauliOp#from_operator "qiskit.quantum_info.SparsePauliOp.from_operator") now uses an implementation of the “tensorized Pauli decomposition algorithm” presented in [Hatznko, Binkowski and Gupta (2023)](https://arxiv.org/abs/2310.13421). The method is now several orders of magnitude faster; for example, it is possible to decompose a random 10-qubit operator in around 250ms on a consumer Macbook Pro (Intel i7, 2020). ### Synthesis Features -* Added a [`qiskit.synthesis.synth_circuit_from_stabilizers()`](/api/qiskit/synthesis#qiskit.synthesis.synth_circuit_from_stabilizers "qiskit.synthesis.synth_circuit_from_stabilizers") function that returns a circuit that outputs the state stabilized by a series of given stabilizers. +* Added a [`qiskit.synthesis.synth_circuit_from_stabilizers()`](/api/qiskit/1.0/synthesis#qiskit.synthesis.synth_circuit_from_stabilizers "qiskit.synthesis.synth_circuit_from_stabilizers") function that returns a circuit that outputs the state stabilized by a series of given stabilizers. * The AQC unitary synthesis plugin method now uses a faster objective function evaluation by default, which results in substantial improvement in synthesis time. -* Add a new synthesis method [`synth_qft_line()`](/api/qiskit/synthesis#qiskit.synthesis.synth_qft_line "qiskit.synthesis.synth_qft_line") of a QFT circuit for linear nearest-neighbor connectivity, which significantly reduces the number of SWAPs for large numbers of qubits compared to SABRE. +* Add a new synthesis method [`synth_qft_line()`](/api/qiskit/1.0/synthesis#qiskit.synthesis.synth_qft_line "qiskit.synthesis.synth_qft_line") of a QFT circuit for linear nearest-neighbor connectivity, which significantly reduces the number of SWAPs for large numbers of qubits compared to SABRE. -* The class [`TwoQubitWeylDecomposition`](/api/qiskit/qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.TwoQubitWeylDecomposition") has been added to the public API in [`qiskit.synthesis`](/api/qiskit/synthesis#module-qiskit.synthesis "qiskit.synthesis"). This class allows to apply the Weyl decomposition of two-qubit unitaries. If you were previously importing this while it was a non-public class in the now-removed `qiskit.quantum_info.synthesis` module, you should update your import paths. +* The class [`TwoQubitWeylDecomposition`](/api/qiskit/1.0/qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.TwoQubitWeylDecomposition") has been added to the public API in [`qiskit.synthesis`](/api/qiskit/1.0/synthesis#module-qiskit.synthesis "qiskit.synthesis"). This class allows to apply the Weyl decomposition of two-qubit unitaries. If you were previously importing this while it was a non-public class in the now-removed `qiskit.quantum_info.synthesis` module, you should update your import paths. ### Transpiler Features -* Added a new exception class: [`InvalidLayoutError`](/api/qiskit/transpiler#qiskit.transpiler.InvalidLayoutError "qiskit.transpiler.InvalidLayoutError"). This is a [`TranspilerError`](/api/qiskit/transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") subclass which is raised when a user provided layout is invalid (mismatched size, duplicate qubits, etc). +* Added a new exception class: [`InvalidLayoutError`](/api/qiskit/1.0/transpiler#qiskit.transpiler.InvalidLayoutError "qiskit.transpiler.InvalidLayoutError"). This is a [`TranspilerError`](/api/qiskit/1.0/transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") subclass which is raised when a user provided layout is invalid (mismatched size, duplicate qubits, etc). -* Added a new keyword argument, `num_processes`, to [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") and the [`PassManager.run()`](/api/qiskit/qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") method. This allows for overriding both `QISKIT_NUM_PROCS` and the `num_processes` field in user configuration files on a per-transpile basis. For example: +* Added a new keyword argument, `num_processes`, to [`transpile()`](/api/qiskit/1.0/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") and the [`PassManager.run()`](/api/qiskit/1.0/qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") method. This allows for overriding both `QISKIT_NUM_PROCS` and the `num_processes` field in user configuration files on a per-transpile basis. For example: ```python from qiskit import transpile, QuantumCircuit @@ -455,9 +455,9 @@ This guide is meant to complement the release notes and have a targeted advice f transpile([qc]*10, basis_gates=['u', 'cz'], num_processes=2) ``` - will run the transpile over the 10 input circuits using only 2 processes and will override the system default, environment variable, or user configuration file for that [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") call. + will run the transpile over the 10 input circuits using only 2 processes and will override the system default, environment variable, or user configuration file for that [`transpile()`](/api/qiskit/1.0/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") call. -* Added a new transpiler pass, [`OptimizeAnnotated`](/api/qiskit/qiskit.transpiler.passes.OptimizeAnnotated "qiskit.transpiler.passes.OptimizeAnnotated"), that optimizes annotated operations on a quantum circuit. +* Added a new transpiler pass, [`OptimizeAnnotated`](/api/qiskit/1.0/qiskit.transpiler.passes.OptimizeAnnotated "qiskit.transpiler.passes.OptimizeAnnotated"), that optimizes annotated operations on a quantum circuit. Consider the following example: @@ -504,11 +504,11 @@ This guide is meant to complement the release notes and have a targeted advice f assert qc_optimized == qc_expected ``` - In the case of `gate1`, the modifiers of the annotated swap gate are brought into the canonical form: the two [`InverseModifier`](/api/qiskit/qiskit.circuit.InverseModifier "qiskit.circuit.InverseModifier")s cancel out, and the two [`ControlModifier`](/api/qiskit/qiskit.circuit.ControlModifier "qiskit.circuit.ControlModifier")s are combined. In the case of `gate2`, all the modifiers get removed and the annotated operation is replaced by its base operation. In the case of `gate3`, multiple layers of annotations are combined into one. + In the case of `gate1`, the modifiers of the annotated swap gate are brought into the canonical form: the two [`InverseModifier`](/api/qiskit/1.0/qiskit.circuit.InverseModifier "qiskit.circuit.InverseModifier")s cancel out, and the two [`ControlModifier`](/api/qiskit/1.0/qiskit.circuit.ControlModifier "qiskit.circuit.ControlModifier")s are combined. In the case of `gate2`, all the modifiers get removed and the annotated operation is replaced by its base operation. In the case of `gate3`, multiple layers of annotations are combined into one. - The constructor of the [`OptimizeAnnotated`](/api/qiskit/qiskit.transpiler.passes.OptimizeAnnotated "qiskit.transpiler.passes.OptimizeAnnotated") pass accepts optional arguments `target`, `equivalence_library`, `basis_gates` and `recurse`. When `recurse` is `True` (the default value) and when either `target` or `basis_gates` are specified, the pass recursively descends into the gate’s `definition` circuits, with the exception of gates that are already supported by the target or that belong to the equivalence library. On the other hand, when neither `target` nor `basis_gates` are specified, or when `recurse` is set to `False`, the pass synthesizes only the “top-level” annotated operations, i.e. does not recursively descend into the `definition` circuits. This behavior is consistent with that of the [`HighLevelSynthesis`](/api/qiskit/qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis") transpiler pass, which needs to be called in order to “unroll” the annotated operations into 1-qubit and 2-qubits gates. + The constructor of the [`OptimizeAnnotated`](/api/qiskit/1.0/qiskit.transpiler.passes.OptimizeAnnotated "qiskit.transpiler.passes.OptimizeAnnotated") pass accepts optional arguments `target`, `equivalence_library`, `basis_gates` and `recurse`. When `recurse` is `True` (the default value) and when either `target` or `basis_gates` are specified, the pass recursively descends into the gate’s `definition` circuits, with the exception of gates that are already supported by the target or that belong to the equivalence library. On the other hand, when neither `target` nor `basis_gates` are specified, or when `recurse` is set to `False`, the pass synthesizes only the “top-level” annotated operations, i.e. does not recursively descend into the `definition` circuits. This behavior is consistent with that of the [`HighLevelSynthesis`](/api/qiskit/1.0/qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis") transpiler pass, which needs to be called in order to “unroll” the annotated operations into 1-qubit and 2-qubits gates. -* Added a new [`HighLevelSynthesisPlugin`](/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") for [`PermutationGate`](/api/qiskit/qiskit.circuit.library.PermutationGate "qiskit.circuit.library.PermutationGate") objects based on Qiskit’s token swapper algorithm. To use this plugin, specify `token_swapper` when defining high-level-synthesis config. +* Added a new [`HighLevelSynthesisPlugin`](/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") for [`PermutationGate`](/api/qiskit/1.0/qiskit.circuit.library.PermutationGate "qiskit.circuit.library.PermutationGate") objects based on Qiskit’s token swapper algorithm. To use this plugin, specify `token_swapper` when defining high-level-synthesis config. This synthesis plugin is able to run before or after the layout is set. When synthesis succeeds, the plugin outputs a quantum circuit consisting only of swap gates. When synthesis does not succeed, the plugin outputs `None`. @@ -545,7 +545,7 @@ This guide is meant to complement the release notes and have a targeted advice f qc_transpiled = pm.run(qc) ``` -* Added two new arguments, `matrix_based` and `max_qubits`, to the constructor of the [`CommutativeInverseCancellation`](/api/qiskit/qiskit.transpiler.passes.CommutativeInverseCancellation "qiskit.transpiler.passes.CommutativeInverseCancellation") transpiler pass. When `matrix_based` is `True`, the pass uses matrix representations to check whether two operations are the inverse of each other. This makes the checks more powerful, and in addition allows for cancelling pairs of operations that are inverse up to a phase, while updating the global phase of the circuit accordingly. This generally leads to more reductions at the expense of increased runtime. The argument `max_qubits` limits the number of qubits in matrix-based commutativity and inverse checks. For example: +* Added two new arguments, `matrix_based` and `max_qubits`, to the constructor of the [`CommutativeInverseCancellation`](/api/qiskit/1.0/qiskit.transpiler.passes.CommutativeInverseCancellation "qiskit.transpiler.passes.CommutativeInverseCancellation") transpiler pass. When `matrix_based` is `True`, the pass uses matrix representations to check whether two operations are the inverse of each other. This makes the checks more powerful, and in addition allows for cancelling pairs of operations that are inverse up to a phase, while updating the global phase of the circuit accordingly. This generally leads to more reductions at the expense of increased runtime. The argument `max_qubits` limits the number of qubits in matrix-based commutativity and inverse checks. For example: ```python import numpy as np @@ -563,13 +563,13 @@ This guide is meant to complement the release notes and have a targeted advice f The pass is able to cancel the `RZ` and `P` gates, while adjusting the circuit’s global phase to $\frac{15 \pi}{8}$. -* Added a new function, [`high_level_synthesis_plugin_names()`](/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names "qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names"), that can be used to get the list of installed high level synthesis plugins for a given operation name. +* Added a new function, [`high_level_synthesis_plugin_names()`](/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names "qiskit.transpiler.passes.synthesis.plugin.high_level_synthesis_plugin_names"), that can be used to get the list of installed high level synthesis plugins for a given operation name. ### Visualization Features -* The `text` and `mpl` outputs for the [`QuantumCircuit.draw()`](/api/qiskit/qiskit.circuit.QuantumCircuit#draw "qiskit.circuit.QuantumCircuit.draw") and [`circuit_drawer()`](/api/qiskit/qiskit.visualization.circuit_drawer "qiskit.visualization.circuit_drawer") circuit drawer functions will now display detailed information for operations of [`AnnotatedOperation`](/api/qiskit/qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). If the `AnnotatedOperation.modifiers` contains a [`ControlModifier`](/api/qiskit/qiskit.circuit.ControlModifier "qiskit.circuit.ControlModifier"), the operation will be displayed the same way as controlled gates. If the [`InverseModifier`](/api/qiskit/qiskit.circuit.InverseModifier "qiskit.circuit.InverseModifier") or [`PowerModifier`](/api/qiskit/qiskit.circuit.PowerModifier "qiskit.circuit.PowerModifier") is used, these will be indicated with the base operation name. For example: +* The `text` and `mpl` outputs for the [`QuantumCircuit.draw()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#draw "qiskit.circuit.QuantumCircuit.draw") and [`circuit_drawer()`](/api/qiskit/1.0/qiskit.visualization.circuit_drawer "qiskit.visualization.circuit_drawer") circuit drawer functions will now display detailed information for operations of [`AnnotatedOperation`](/api/qiskit/1.0/qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). If the `AnnotatedOperation.modifiers` contains a [`ControlModifier`](/api/qiskit/1.0/qiskit.circuit.ControlModifier "qiskit.circuit.ControlModifier"), the operation will be displayed the same way as controlled gates. If the [`InverseModifier`](/api/qiskit/1.0/qiskit.circuit.InverseModifier "qiskit.circuit.InverseModifier") or [`PowerModifier`](/api/qiskit/1.0/qiskit.circuit.PowerModifier "qiskit.circuit.PowerModifier") is used, these will be indicated with the base operation name. For example: ```python from qiskit.circuit import ( @@ -593,23 +593,23 @@ This guide is meant to complement the release notes and have a targeted advice f ### Misc. Features -* Added a new warning base class, [`QiskitWarning`](/api/qiskit/exceptions#qiskit.exceptions.QiskitWarning "qiskit.exceptions.QiskitWarning"). While Qiskit will continue to use built-in Python warnings (such as [`DeprecationWarning`](https://docs.python.org/3/library/exceptions.html#DeprecationWarning "(in Python v3.12)")) when those are most appropriate, for cases that are more specific to Qiskit, the warnings will be subclasses of [`QiskitWarning`](/api/qiskit/exceptions#qiskit.exceptions.QiskitWarning "qiskit.exceptions.QiskitWarning"). +* Added a new warning base class, [`QiskitWarning`](/api/qiskit/1.0/exceptions#qiskit.exceptions.QiskitWarning "qiskit.exceptions.QiskitWarning"). While Qiskit will continue to use built-in Python warnings (such as [`DeprecationWarning`](https://docs.python.org/3/library/exceptions.html#DeprecationWarning "(in Python v3.12)")) when those are most appropriate, for cases that are more specific to Qiskit, the warnings will be subclasses of [`QiskitWarning`](/api/qiskit/1.0/exceptions#qiskit.exceptions.QiskitWarning "qiskit.exceptions.QiskitWarning"). -* The optional-functionality testers ([`qiskit.utils.optionals`](/api/qiskit/utils#module-qiskit.utils.optionals "qiskit.utils.optionals")) will now distinguish an optional dependency that was completely not found (a normal situation) with one that was found, but triggered errors during its import. In the latter case, they will now issue an [`OptionalDependencyImportWarning`](/api/qiskit/exceptions#qiskit.exceptions.OptionalDependencyImportWarning "qiskit.exceptions.OptionalDependencyImportWarning") telling you what happened, since it might indicate a failed installation or an incompatible version. +* The optional-functionality testers ([`qiskit.utils.optionals`](/api/qiskit/1.0/utils#module-qiskit.utils.optionals "qiskit.utils.optionals")) will now distinguish an optional dependency that was completely not found (a normal situation) with one that was found, but triggered errors during its import. In the latter case, they will now issue an [`OptionalDependencyImportWarning`](/api/qiskit/1.0/exceptions#qiskit.exceptions.OptionalDependencyImportWarning "qiskit.exceptions.OptionalDependencyImportWarning") telling you what happened, since it might indicate a failed installation or an incompatible version. ### Upgrade Notes -* Qiskit 1.0 now requires version 0.14.0 of `rustworkx`. The minimum version requirement was raised to support the new `token_swapper` [`PermutationGate`](/api/qiskit/qiskit.circuit.library.PermutationGate "qiskit.circuit.library.PermutationGate") synthesis plugin for [`HighLevelSynthesisPlugin`](/api/qiskit/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin"). +* Qiskit 1.0 now requires version 0.14.0 of `rustworkx`. The minimum version requirement was raised to support the new `token_swapper` [`PermutationGate`](/api/qiskit/1.0/qiskit.circuit.library.PermutationGate "qiskit.circuit.library.PermutationGate") synthesis plugin for [`HighLevelSynthesisPlugin`](/api/qiskit/1.0/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin"). * The minimum supported Rust version for building Qiskit from source is now 1.70. This has been raised from the previous minimum supported Rust version of 1.64 in the Qiskit 0.45.x and 0.46.0 release series. -* The dependency on [psutil](https://pypi.org/project/psutil/) has been removed. The psutil library was previously only used for detecting the number of physical CPUs and total system memory, however this information provided does not add sufficient value to justify the additional dependencies and overhead so it has been removed. This does mean that the default number of processes used by [`parallel_map()`](/api/qiskit/utils#qiskit.utils.parallel_map "qiskit.utils.parallel_map") and functions that internally can use [`parallel_map()`](/api/qiskit/utils#qiskit.utils.parallel_map "qiskit.utils.parallel_map") such as [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") and [`PassManager.run()`](/api/qiskit/qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") may use more or less parallel processes than in previous releases. If you’d like to adjust the number of processes used you can use the new `num_processes` argument to those functions, or the `QISKIT_NUM_PROCS` environment variable or `num_processes` field in a user configuration file (see the [local configuration guide](/start/configure-qiskit-local) for more details) if you need to adjust the number of processes that Qiskit potentially uses. +* The dependency on [psutil](https://pypi.org/project/psutil/) has been removed. The psutil library was previously only used for detecting the number of physical CPUs and total system memory, however this information provided does not add sufficient value to justify the additional dependencies and overhead so it has been removed. This does mean that the default number of processes used by [`parallel_map()`](/api/qiskit/1.0/utils#qiskit.utils.parallel_map "qiskit.utils.parallel_map") and functions that internally can use [`parallel_map()`](/api/qiskit/1.0/utils#qiskit.utils.parallel_map "qiskit.utils.parallel_map") such as [`transpile()`](/api/qiskit/1.0/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") and [`PassManager.run()`](/api/qiskit/1.0/qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") may use more or less parallel processes than in previous releases. If you’d like to adjust the number of processes used you can use the new `num_processes` argument to those functions, or the `QISKIT_NUM_PROCS` environment variable or `num_processes` field in a user configuration file (see the [local configuration guide](/start/configure-qiskit-local) for more details) if you need to adjust the number of processes that Qiskit potentially uses. -* The `scoped_parameters` and `search_parameters` methods have been removed from the [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") class. These methods returned [`Parameter`](/api/qiskit/qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects that partially linked to the parameters in the [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") instance but assigning values using these objects did not work correctly. Users should use [`ScheduleBlock.parameters`](/api/qiskit/qiskit.pulse.ScheduleBlock#parameters "qiskit.pulse.ScheduleBlock.parameters") instead and iterate through [`ScheduleBlock.references`](/api/qiskit/qiskit.pulse.ScheduleBlock#references "qiskit.pulse.ScheduleBlock.references") and compare to the [`Schedule.parameters`](/api/qiskit/qiskit.pulse.Schedule#parameters "qiskit.pulse.Schedule.parameters") attributes of the subreferences when needing to distinguish which subroutine a parameter is used in. See [#11654](https://github.com/Qiskit/qiskit/issues/11654) for more information. +* The `scoped_parameters` and `search_parameters` methods have been removed from the [`ScheduleBlock`](/api/qiskit/1.0/qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") class. These methods returned [`Parameter`](/api/qiskit/1.0/qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects that partially linked to the parameters in the [`ScheduleBlock`](/api/qiskit/1.0/qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") instance but assigning values using these objects did not work correctly. Users should use [`ScheduleBlock.parameters`](/api/qiskit/1.0/qiskit.pulse.ScheduleBlock#parameters "qiskit.pulse.ScheduleBlock.parameters") instead and iterate through [`ScheduleBlock.references`](/api/qiskit/1.0/qiskit.pulse.ScheduleBlock#references "qiskit.pulse.ScheduleBlock.references") and compare to the [`Schedule.parameters`](/api/qiskit/1.0/qiskit.pulse.Schedule#parameters "qiskit.pulse.Schedule.parameters") attributes of the subreferences when needing to distinguish which subroutine a parameter is used in. See [#11654](https://github.com/Qiskit/qiskit/issues/11654) for more information. -* Removed logic for injecting [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") and [`Gate`](/api/qiskit/qiskit.circuit.Gate "qiskit.circuit.Gate") operations into the pulse context (such as in [`pulse.builder.call()`](/api/qiskit/pulse#qiskit.pulse.builder.call "qiskit.pulse.builder.call")), which was legacy behavior deprecated in Qiskit 0.46. Pulse schedules should be built up as a full schedule context; circuits and gates are a higher level of abstraction. +* Removed logic for injecting [`QuantumCircuit`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") and [`Gate`](/api/qiskit/1.0/qiskit.circuit.Gate "qiskit.circuit.Gate") operations into the pulse context (such as in [`pulse.builder.call()`](/api/qiskit/1.0/pulse#qiskit.pulse.builder.call "qiskit.pulse.builder.call")), which was legacy behavior deprecated in Qiskit 0.46. Pulse schedules should be built up as a full schedule context; circuits and gates are a higher level of abstraction. This includes the removal of the related functions: @@ -624,7 +624,7 @@ This guide is meant to complement the release notes and have a targeted advice f * `pulse.builder.transpiler_settings` * `pulse.builder.circuit_scheduler_settings` - The `default_transpiler_settings` and `default_circuit_scheduler_settings` arguments to [`pulse.builder.build()`](/api/qiskit/pulse#qiskit.pulse.builder.build "qiskit.pulse.builder.build") are similarly removed. + The `default_transpiler_settings` and `default_circuit_scheduler_settings` arguments to [`pulse.builder.build()`](/api/qiskit/1.0/pulse#qiskit.pulse.builder.build "qiskit.pulse.builder.build") are similarly removed. ```python from qiskit import transpile, schedule, QuantumCircuit, pulse @@ -656,33 +656,33 @@ This guide is meant to complement the release notes and have a targeted advice f ### Circuits Upgrade Notes -* Removed the `Instruction.qasm` method, which was deprecated in Qiskit 0.45.0. Use [`qiskit.qasm2.dump()`](/api/qiskit/qasm2#qiskit.qasm2.dump "qiskit.qasm2.dump") with a complete [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") instead. +* Removed the `Instruction.qasm` method, which was deprecated in Qiskit 0.45.0. Use [`qiskit.qasm2.dump()`](/api/qiskit/1.0/qasm2#qiskit.qasm2.dump "qiskit.qasm2.dump") with a complete [`QuantumCircuit`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") instead. -* The properties `Bit.register` and `Bit.index` are removed. They were deprecated in Qiskit 0.25 (released in 2021-04). The qubits and bits now live only in the context of a [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). The alternative to the properties is to use [`QuantumCircuit.find_bit()`](/api/qiskit/qiskit.circuit.QuantumCircuit#find_bit "qiskit.circuit.QuantumCircuit.find_bit") to find all the containing registers within a circuit and the index of the bit within the circuit. +* The properties `Bit.register` and `Bit.index` are removed. They were deprecated in Qiskit 0.25 (released in 2021-04). The qubits and bits now live only in the context of a [`QuantumCircuit`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). The alternative to the properties is to use [`QuantumCircuit.find_bit()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#find_bit "qiskit.circuit.QuantumCircuit.find_bit") to find all the containing registers within a circuit and the index of the bit within the circuit. -* The method `QuantumCircuit.bind_parameters` has been removed, following its deprecation in Qiskit 0.45. You can use [`QuantumCircuit.assign_parameters()`](/api/qiskit/qiskit.circuit.QuantumCircuit#assign_parameters "qiskit.circuit.QuantumCircuit.assign_parameters") as a drop-in replacement with all its defaults, and it also exposes additional features over the old method. +* The method `QuantumCircuit.bind_parameters` has been removed, following its deprecation in Qiskit 0.45. You can use [`QuantumCircuit.assign_parameters()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#assign_parameters "qiskit.circuit.QuantumCircuit.assign_parameters") as a drop-in replacement with all its defaults, and it also exposes additional features over the old method. -* Importing `Int1`, `Int2`, `BooleanFunction`, `classical_function()` from [`qiskit.circuit`](/api/qiskit/circuit#module-qiskit.circuit "qiskit.circuit") is now disabled. Instead, import the objects from the [`qiskit.circuit.classicalfunction`](/api/qiskit/classicalfunction#module-qiskit.circuit.classicalfunction "qiskit.circuit.classicalfunction") submodule, which requires the `tweedledum` package. +* Importing `Int1`, `Int2`, `BooleanFunction`, `classical_function()` from [`qiskit.circuit`](/api/qiskit/1.0/circuit#module-qiskit.circuit "qiskit.circuit") is now disabled. Instead, import the objects from the [`qiskit.circuit.classicalfunction`](/api/qiskit/1.0/classicalfunction#module-qiskit.circuit.classicalfunction "qiskit.circuit.classicalfunction") submodule, which requires the `tweedledum` package. -* The `header` and `extension_lib` data-only attributes from [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") are removed following their deprecation in Qiskit 0.45. These were internal details of the OpenQASM 2 exporter which are no longer used. +* The `header` and `extension_lib` data-only attributes from [`QuantumCircuit`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") are removed following their deprecation in Qiskit 0.45. These were internal details of the OpenQASM 2 exporter which are no longer used. -* Removed the `qiskit.extensions` module, which has been pending deprecation since the 0.45 release and has been fully deprecated in the 0.46 release. The following operations from this module are available in [`qiskit.circuit.library`](/api/qiskit/circuit_library#module-qiskit.circuit.library "qiskit.circuit.library"): +* Removed the `qiskit.extensions` module, which has been pending deprecation since the 0.45 release and has been fully deprecated in the 0.46 release. The following operations from this module are available in [`qiskit.circuit.library`](/api/qiskit/1.0/circuit_library#module-qiskit.circuit.library "qiskit.circuit.library"): - > * [`DiagonalGate`](/api/qiskit/qiskit.circuit.library.DiagonalGate "qiskit.circuit.library.DiagonalGate"), + > * [`DiagonalGate`](/api/qiskit/1.0/qiskit.circuit.library.DiagonalGate "qiskit.circuit.library.DiagonalGate"), > * `HamiltonianGateGate`, - > * [`Initialize`](/api/qiskit/qiskit.circuit.library.Initialize "qiskit.circuit.library.Initialize"), - > * [`Isometry`](/api/qiskit/qiskit.circuit.library.Isometry "qiskit.circuit.library.Isometry"), + > * [`Initialize`](/api/qiskit/1.0/qiskit.circuit.library.Initialize "qiskit.circuit.library.Initialize"), + > * [`Isometry`](/api/qiskit/1.0/qiskit.circuit.library.Isometry "qiskit.circuit.library.Isometry"), > * `MCGupDiag`, - > * [`UCGate`](/api/qiskit/qiskit.circuit.library.UCGate "qiskit.circuit.library.UCGate"), - > * [`UCPauliRotGate`](/api/qiskit/qiskit.circuit.library.UCPauliRotGate "qiskit.circuit.library.UCPauliRotGate"), - > * [`UCRXGate`](/api/qiskit/qiskit.circuit.library.UCRXGate "qiskit.circuit.library.UCRXGate"), - > * [`UCRYGate`](/api/qiskit/qiskit.circuit.library.UCRYGate "qiskit.circuit.library.UCRYGate"), - > * [`UCRZGate`](/api/qiskit/qiskit.circuit.library.UCRZGate "qiskit.circuit.library.UCRZGate"), - > * [`UnitaryGate`](/api/qiskit/qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate"). + > * [`UCGate`](/api/qiskit/1.0/qiskit.circuit.library.UCGate "qiskit.circuit.library.UCGate"), + > * [`UCPauliRotGate`](/api/qiskit/1.0/qiskit.circuit.library.UCPauliRotGate "qiskit.circuit.library.UCPauliRotGate"), + > * [`UCRXGate`](/api/qiskit/1.0/qiskit.circuit.library.UCRXGate "qiskit.circuit.library.UCRXGate"), + > * [`UCRYGate`](/api/qiskit/1.0/qiskit.circuit.library.UCRYGate "qiskit.circuit.library.UCRYGate"), + > * [`UCRZGate`](/api/qiskit/1.0/qiskit.circuit.library.UCRZGate "qiskit.circuit.library.UCRZGate"), + > * [`UnitaryGate`](/api/qiskit/1.0/qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate"). The following objects have been removed: - > * `SingleQubitUnitary` (instead use [`library.UnitaryGate`](/api/qiskit/qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")), + > * `SingleQubitUnitary` (instead use [`library.UnitaryGate`](/api/qiskit/1.0/qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")), > * `Snapshot` (superseded by Aer’s save instructions), > * `ExtensionError`, @@ -700,15 +700,15 @@ This guide is meant to complement the release notes and have a targeted advice f These operations can still be performed by appending the appropriate instruction to a quantum circuit. -* Removed deprecated, duplicated [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") methods. These include: +* Removed deprecated, duplicated [`QuantumCircuit`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") methods. These include: - > * `QuantumCircuit.cnot`, instead use [`QuantumCircuit.cx()`](/api/qiskit/qiskit.circuit.QuantumCircuit#cx "qiskit.circuit.QuantumCircuit.cx"), - > * `QuantumCircuit.toffoli`, instead use [`QuantumCircuit.ccx()`](/api/qiskit/qiskit.circuit.QuantumCircuit#ccx "qiskit.circuit.QuantumCircuit.ccx"), - > * `QuantumCircuit.fredkin`, instead use [`QuantumCircuit.cswap()`](/api/qiskit/qiskit.circuit.QuantumCircuit#cswap "qiskit.circuit.QuantumCircuit.cswap"), - > * `QuantumCircuit.mct`, instead use [`QuantumCircuit.mcx()`](/api/qiskit/qiskit.circuit.QuantumCircuit#mcx "qiskit.circuit.QuantumCircuit.mcx"), - > * `QuantumCircuit.i`, instead use [`QuantumCircuit.id()`](/api/qiskit/qiskit.circuit.QuantumCircuit#id "qiskit.circuit.QuantumCircuit.id"). + > * `QuantumCircuit.cnot`, instead use [`QuantumCircuit.cx()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#cx "qiskit.circuit.QuantumCircuit.cx"), + > * `QuantumCircuit.toffoli`, instead use [`QuantumCircuit.ccx()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#ccx "qiskit.circuit.QuantumCircuit.ccx"), + > * `QuantumCircuit.fredkin`, instead use [`QuantumCircuit.cswap()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#cswap "qiskit.circuit.QuantumCircuit.cswap"), + > * `QuantumCircuit.mct`, instead use [`QuantumCircuit.mcx()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#mcx "qiskit.circuit.QuantumCircuit.mcx"), + > * `QuantumCircuit.i`, instead use [`QuantumCircuit.id()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#id "qiskit.circuit.QuantumCircuit.id"). -* You can no longer set [`QuantumCircuit.metadata`](/api/qiskit/qiskit.circuit.QuantumCircuit#metadata "qiskit.circuit.QuantumCircuit.metadata") to be `None`, following deprecation in Qiskit 0.43.0. Its type is [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)"), so to clear it, set it to `{}`. +* You can no longer set [`QuantumCircuit.metadata`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#metadata "qiskit.circuit.QuantumCircuit.metadata") to be `None`, following deprecation in Qiskit 0.43.0. Its type is [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)"), so to clear it, set it to `{}`. * The attribute `.Register.name_format` has been removed following its deprecation in Qiskit 0.40.0. There is no restriction on register names any more, and the regular expression there was simply `[a-z][a-zA-Z0-9_]*`. @@ -716,29 +716,29 @@ This guide is meant to complement the release notes and have a targeted advice f ### Primitives Upgrade Notes -* Added the [`BasePrimitiveJob`](/api/qiskit/qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob") class as an abstract job class for primitives and made [`PrimitiveJob`](/api/qiskit/qiskit.primitives.PrimitiveJob "qiskit.primitives.PrimitiveJob") inherit [`BasePrimitiveJob`](/api/qiskit/qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob") instead of [`JobV1`](/api/qiskit/qiskit.providers.JobV1 "qiskit.providers.JobV1"). +* Added the [`BasePrimitiveJob`](/api/qiskit/1.0/qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob") class as an abstract job class for primitives and made [`PrimitiveJob`](/api/qiskit/1.0/qiskit.primitives.PrimitiveJob "qiskit.primitives.PrimitiveJob") inherit [`BasePrimitiveJob`](/api/qiskit/1.0/qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob") instead of [`JobV1`](/api/qiskit/1.0/qiskit.providers.JobV1 "qiskit.providers.JobV1"). ### Providers Upgrade Notes -* Changed default value of two arguments (`add_delay` and `filter_faulty`) in the [`convert_to_target()`](/api/qiskit/qiskit.providers.convert_to_target "qiskit.providers.convert_to_target") function. This conversion function now adds delay instructions and removes faulty instructions by default. +* Changed default value of two arguments (`add_delay` and `filter_faulty`) in the [`convert_to_target()`](/api/qiskit/1.0/qiskit.providers.convert_to_target "qiskit.providers.convert_to_target") function. This conversion function now adds delay instructions and removes faulty instructions by default. -* The [`BackendProperties`](/api/qiskit/qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") and [`PulseDefaults`](/api/qiskit/qiskit.providers.models.PulseDefaults "qiskit.providers.models.PulseDefaults") model objects used by the [`FakeOpenPulse2Q`](/api/qiskit/qiskit.providers.fake_provider.FakeOpenPulse2Q "qiskit.providers.fake_provider.FakeOpenPulse2Q") have been updated to be internally consistent and add missing instructions. If you were relying on the previous model objects as a compilation target you can use the backend with Qiskit 0.46 and export a [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") generated with [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") and serialize it using `qpy.dump` to access it in this release. +* The [`BackendProperties`](/api/qiskit/1.0/qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") and [`PulseDefaults`](/api/qiskit/1.0/qiskit.providers.models.PulseDefaults "qiskit.providers.models.PulseDefaults") model objects used by the [`FakeOpenPulse2Q`](/api/qiskit/1.0/qiskit.providers.fake_provider.FakeOpenPulse2Q "qiskit.providers.fake_provider.FakeOpenPulse2Q") have been updated to be internally consistent and add missing instructions. If you were relying on the previous model objects as a compilation target you can use the backend with Qiskit 0.46 and export a [`QuantumCircuit`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") generated with [`transpile()`](/api/qiskit/1.0/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") and serialize it using `qpy.dump` to access it in this release. -* The `qiskit.providers.basicaer` module, exposed as `qiskit.BasicAer`, has been removed following it deprecation on the 0.46 release. Its functionality has been replaced by the [`qiskit.quantum_info`](/api/qiskit/quantum_info#module-qiskit.quantum_info "qiskit.quantum_info") module and the new [`qiskit.providers.basic_provider`](/api/qiskit/providers_basic_provider#module-qiskit.providers.basic_provider "qiskit.providers.basic_provider") module. +* The `qiskit.providers.basicaer` module, exposed as `qiskit.BasicAer`, has been removed following it deprecation on the 0.46 release. Its functionality has been replaced by the [`qiskit.quantum_info`](/api/qiskit/1.0/quantum_info#module-qiskit.quantum_info "qiskit.quantum_info") module and the new [`qiskit.providers.basic_provider`](/api/qiskit/1.0/providers_basic_provider#module-qiskit.providers.basic_provider "qiskit.providers.basic_provider") module. - The migration from using `qiskit.providers.basicaer` (`qiskit.BasicAer`) to [`qiskit.providers.basic_provider`](/api/qiskit/providers_basic_provider#module-qiskit.providers.basic_provider "qiskit.providers.basic_provider") can be performed as follows: + The migration from using `qiskit.providers.basicaer` (`qiskit.BasicAer`) to [`qiskit.providers.basic_provider`](/api/qiskit/1.0/providers_basic_provider#module-qiskit.providers.basic_provider "qiskit.providers.basic_provider") can be performed as follows: | Migrate from | Replace with | | --------------------------- | ------------------------------------------------------------------------------------------------------------------------- | | `qiskit.BasicAer` | The new provider doesn’t have a global instance, imports should be from `qiskit.providers.basic_provider` | - | `qiskit.providers.basicaer` | [`basic_provider`](/api/qiskit/providers_basic_provider#module-qiskit.providers.basic_provider "qiskit.providers.basic_provider") | - | `BasicAerProvider` | [`BasicProvider`](/api/qiskit/qiskit.providers.basic_provider.BasicProvider "qiskit.providers.basic_provider.BasicProvider") | - | `BasicAerJob` | [`BasicProviderJob`](/api/qiskit/qiskit.providers.basic_provider.BasicProviderJob "qiskit.providers.basic_provider.BasicProviderJob") | - | `QasmSimulatorPy` | [`BasicSimulator`](/api/qiskit/qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") | - | `UnitarySimulatorPy` | use [`Operator`](/api/qiskit/qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") | - | `StatevectorSimulatorPy` | use [`Statevector`](/api/qiskit/qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") | + | `qiskit.providers.basicaer` | [`basic_provider`](/api/qiskit/1.0/providers_basic_provider#module-qiskit.providers.basic_provider "qiskit.providers.basic_provider") | + | `BasicAerProvider` | [`BasicProvider`](/api/qiskit/1.0/qiskit.providers.basic_provider.BasicProvider "qiskit.providers.basic_provider.BasicProvider") | + | `BasicAerJob` | [`BasicProviderJob`](/api/qiskit/1.0/qiskit.providers.basic_provider.BasicProviderJob "qiskit.providers.basic_provider.BasicProviderJob") | + | `QasmSimulatorPy` | [`BasicSimulator`](/api/qiskit/1.0/qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") | + | `UnitarySimulatorPy` | use [`Operator`](/api/qiskit/1.0/qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") | + | `StatevectorSimulatorPy` | use [`Statevector`](/api/qiskit/1.0/qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") | A notable difference is that the new provider is no longer exposed through a global instance (like `BasicAer`), so it will not be valid to do `from qiskit import BasicProvider`. Instead, the provider class must be imported from its submodule and instantiated manually: @@ -814,9 +814,9 @@ This guide is meant to complement the release notes and have a targeted advice f result = backend.run(qc).result() ``` -* Removed the `ConfigurableFakeBackend` class deprecated in Qiskit 0.46.0. Instead, a suitable [`FakeBackend`](/api/qiskit/providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.FakeBackend") can be used. +* Removed the `ConfigurableFakeBackend` class deprecated in Qiskit 0.46.0. Instead, a suitable [`FakeBackend`](/api/qiskit/1.0/providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.FakeBackend") can be used. -* The deprecated [`qiskit.providers.fake_provider`](/api/qiskit/providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider") module has been migrated to the `qiskit-ibm-runtime` Python package. For this reason, the following elements in the [`qiskit.providers.fake_provider`](/api/qiskit/providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider") have been removed following their deprecation in Qiskit 0.46: +* The deprecated [`qiskit.providers.fake_provider`](/api/qiskit/1.0/providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider") module has been migrated to the `qiskit-ibm-runtime` Python package. For this reason, the following elements in the [`qiskit.providers.fake_provider`](/api/qiskit/1.0/providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider") have been removed following their deprecation in Qiskit 0.46: > * `qiskit.providers.fake_provider.FakeProvider` > * `qiskit.providers.fake_provider.FakeProviderForBackendV2` @@ -842,14 +842,14 @@ This guide is meant to complement the release notes and have a targeted advice f backend2 = FakeSherbrooke() ``` - Additionally, the following fake backends designed for special testing purposes have been superseded by the new [`GenericBackendV2`](/api/qiskit/qiskit.providers.fake_provider.GenericBackendV2 "qiskit.providers.fake_provider.GenericBackendV2") class, and are also removed following their deprecation in Qiskit 0.46: + Additionally, the following fake backends designed for special testing purposes have been superseded by the new [`GenericBackendV2`](/api/qiskit/1.0/qiskit.providers.fake_provider.GenericBackendV2 "qiskit.providers.fake_provider.GenericBackendV2") class, and are also removed following their deprecation in Qiskit 0.46: > * `qiskit.providers.fake_provider.fake_backend_v2.FakeBackendV2` > * `` `qiskit.providers.fake_provider.fake_backend_v2.FakeBackendV2LegacyQubitProps `` > * `qiskit.providers.fake_provider.fake_backend_v2.FakeBackend5QV2` > * `qiskit.providers.fake_provider.fake_backend_v2.FakeBackendSimple` - Migration example to the new [`GenericBackendV2`](/api/qiskit/qiskit.providers.fake_provider.GenericBackendV2 "qiskit.providers.fake_provider.GenericBackendV2") class: + Migration example to the new [`GenericBackendV2`](/api/qiskit/1.0/qiskit.providers.fake_provider.GenericBackendV2 "qiskit.providers.fake_provider.GenericBackendV2") class: ```python # Legacy path @@ -893,49 +893,49 @@ This guide is meant to complement the release notes and have a targeted advice f These public methods are all replaced with protected ones which are implicitly called from the single entry point, i.e. calling the class as like a function. -* The class `qiskit.pulse.library.ParametricPulse` and all subclasses are removed. These were deprecated since Qiskit 0.39 (with qiskit-terra 0.22), released in 2022-10. Instead, use [`SymbolicPulse`](/api/qiskit/qiskit.pulse.library.SymbolicPulse "qiskit.pulse.library.SymbolicPulse") and check its documentation for details. +* The class `qiskit.pulse.library.ParametricPulse` and all subclasses are removed. These were deprecated since Qiskit 0.39 (with qiskit-terra 0.22), released in 2022-10. Instead, use [`SymbolicPulse`](/api/qiskit/1.0/qiskit.pulse.library.SymbolicPulse "qiskit.pulse.library.SymbolicPulse") and check its documentation for details. ### OpenQASM Upgrade Notes -* The `qasm()` methods of the classes [`QuantumRegister`](/api/qiskit/qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") and [`ClassicalRegister`](/api/qiskit/qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") have been removed. There is no replacement necessary; these were an internal detail of a legacy implementation of the OpenQASM 2 exporter. To export a program to OpenQASM 2, use [`qasm2.dump()`](/api/qiskit/qasm2#qiskit.qasm2.dump "qiskit.qasm2.dump") or [`qasm2.dumps()`](/api/qiskit/qasm2#qiskit.qasm2.dumps "qiskit.qasm2.dumps"). +* The `qasm()` methods of the classes [`QuantumRegister`](/api/qiskit/1.0/qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") and [`ClassicalRegister`](/api/qiskit/1.0/qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") have been removed. There is no replacement necessary; these were an internal detail of a legacy implementation of the OpenQASM 2 exporter. To export a program to OpenQASM 2, use [`qasm2.dump()`](/api/qiskit/1.0/qasm2#qiskit.qasm2.dump "qiskit.qasm2.dump") or [`qasm2.dumps()`](/api/qiskit/1.0/qasm2#qiskit.qasm2.dumps "qiskit.qasm2.dumps"). ### QPY Upgrade Notes -* The latest format version of QPY is now [Version 11](/api/qiskit/qpy#qpy-version-11) and this is what is emitted by default when running [`qpy.dump()`](/api/qiskit/qpy#qiskit.qpy.dump "qiskit.qpy.dump"). +* The latest format version of QPY is now [Version 11](/api/qiskit/1.0/qpy#qpy-version-11) and this is what is emitted by default when running [`qpy.dump()`](/api/qiskit/1.0/qpy#qiskit.qpy.dump "qiskit.qpy.dump"). -* The module path `qiskit.circuit.qpy_serialization` has been removed, following its deprecation in Qiskit 0.40.0. For QPY serialization, use [`qiskit.qpy`](/api/qiskit/qpy#module-qiskit.qpy "qiskit.qpy"), which is the new location. +* The module path `qiskit.circuit.qpy_serialization` has been removed, following its deprecation in Qiskit 0.40.0. For QPY serialization, use [`qiskit.qpy`](/api/qiskit/1.0/qpy#module-qiskit.qpy "qiskit.qpy"), which is the new location. ### Quantum Information Upgrade Notes -* Removed the deprecated `__getitem__`/`__setitem__` magic methods of [`Clifford`](/api/qiskit/qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford"). The methods were deprecated since Qiskit 0.44, released in 2023-07. Instead, index or iterate through the `Clifford.tableau` attribute. +* Removed the deprecated `__getitem__`/`__setitem__` magic methods of [`Clifford`](/api/qiskit/1.0/qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford"). The methods were deprecated since Qiskit 0.44, released in 2023-07. Instead, index or iterate through the `Clifford.tableau` attribute. -* Removed the `qiskit.quantum_info.synthesis` module, which has been deprecated since the 0.46 release. The following objects have been moved to [`qiskit.synthesis`](/api/qiskit/synthesis#module-qiskit.synthesis "qiskit.synthesis"): +* Removed the `qiskit.quantum_info.synthesis` module, which has been deprecated since the 0.46 release. The following objects have been moved to [`qiskit.synthesis`](/api/qiskit/1.0/synthesis#module-qiskit.synthesis "qiskit.synthesis"): - * [`OneQubitEulerDecomposer`](/api/qiskit/qiskit.synthesis.OneQubitEulerDecomposer "qiskit.synthesis.OneQubitEulerDecomposer") has been moved to `qiskit.synthesis.one_qubit` - * [`TwoQubitBasisDecomposer`](/api/qiskit/qiskit.synthesis.TwoQubitBasisDecomposer "qiskit.synthesis.TwoQubitBasisDecomposer") has been moved to `qiskit.synthesis.two_qubits` - * [`XXDecomposer`](/api/qiskit/qiskit.synthesis.XXDecomposer "qiskit.synthesis.XXDecomposer") has been moved to `qiskit.synthesis.two_qubits` - * [`two_qubit_cnot_decompose()`](/api/qiskit/synthesis#qiskit.synthesis.two_qubit_cnot_decompose "qiskit.synthesis.two_qubit_cnot_decompose") has been moved to `qiskit.synthesis.two_qubits` + * [`OneQubitEulerDecomposer`](/api/qiskit/1.0/qiskit.synthesis.OneQubitEulerDecomposer "qiskit.synthesis.OneQubitEulerDecomposer") has been moved to `qiskit.synthesis.one_qubit` + * [`TwoQubitBasisDecomposer`](/api/qiskit/1.0/qiskit.synthesis.TwoQubitBasisDecomposer "qiskit.synthesis.TwoQubitBasisDecomposer") has been moved to `qiskit.synthesis.two_qubits` + * [`XXDecomposer`](/api/qiskit/1.0/qiskit.synthesis.XXDecomposer "qiskit.synthesis.XXDecomposer") has been moved to `qiskit.synthesis.two_qubits` + * [`two_qubit_cnot_decompose()`](/api/qiskit/1.0/synthesis#qiskit.synthesis.two_qubit_cnot_decompose "qiskit.synthesis.two_qubit_cnot_decompose") has been moved to `qiskit.synthesis.two_qubits` This function was removed, since it has already been deprecated in the 0.46 release: \* `cnot_rxx_decompose` - These functions were removed, since they have already been deprecated in a previous release: \* `decompose_clifford` (use [`synth_clifford_full()`](/api/qiskit/synthesis#qiskit.synthesis.synth_clifford_full "qiskit.synthesis.synth_clifford_full") instead) \* `decompose_cnotdihedral` (use [`synth_cnotdihedral_full()`](/api/qiskit/synthesis#qiskit.synthesis.synth_cnotdihedral_full "qiskit.synthesis.synth_cnotdihedral_full") instead) + These functions were removed, since they have already been deprecated in a previous release: \* `decompose_clifford` (use [`synth_clifford_full()`](/api/qiskit/1.0/synthesis#qiskit.synthesis.synth_clifford_full "qiskit.synthesis.synth_clifford_full") instead) \* `decompose_cnotdihedral` (use [`synth_cnotdihedral_full()`](/api/qiskit/1.0/synthesis#qiskit.synthesis.synth_cnotdihedral_full "qiskit.synthesis.synth_cnotdihedral_full") instead) -* The functions [`process_fidelity()`](/api/qiskit/quantum_info#qiskit.quantum_info.process_fidelity "qiskit.quantum_info.process_fidelity"), [`average_gate_fidelity()`](/api/qiskit/quantum_info#qiskit.quantum_info.average_gate_fidelity "qiskit.quantum_info.average_gate_fidelity"), [`gate_error()`](/api/qiskit/quantum_info#qiskit.quantum_info.gate_error "qiskit.quantum_info.gate_error") and [`diamond_norm()`](/api/qiskit/quantum_info#qiskit.quantum_info.diamond_norm "qiskit.quantum_info.diamond_norm") will no longer attempt to coerce arbitrary inputs to their marked expected types, following the deprecation in Qiskit 0.25.0. Pass inputs of the marked types to each argument directly. +* The functions [`process_fidelity()`](/api/qiskit/1.0/quantum_info#qiskit.quantum_info.process_fidelity "qiskit.quantum_info.process_fidelity"), [`average_gate_fidelity()`](/api/qiskit/1.0/quantum_info#qiskit.quantum_info.average_gate_fidelity "qiskit.quantum_info.average_gate_fidelity"), [`gate_error()`](/api/qiskit/1.0/quantum_info#qiskit.quantum_info.gate_error "qiskit.quantum_info.gate_error") and [`diamond_norm()`](/api/qiskit/1.0/quantum_info#qiskit.quantum_info.diamond_norm "qiskit.quantum_info.diamond_norm") will no longer attempt to coerce arbitrary inputs to their marked expected types, following the deprecation in Qiskit 0.25.0. Pass inputs of the marked types to each argument directly. ### Synthesis Upgrade Notes -* The following deprecated functions previously in [`qiskit.quantum_info`](/api/qiskit/quantum_info#module-qiskit.quantum_info "qiskit.quantum_info") have been removed. These functions were marked as deprecated in the Qiskit 0.40.0 release in 2023-01. +* The following deprecated functions previously in [`qiskit.quantum_info`](/api/qiskit/1.0/quantum_info#module-qiskit.quantum_info "qiskit.quantum_info") have been removed. These functions were marked as deprecated in the Qiskit 0.40.0 release in 2023-01. - > * `decompose_clifford`: you should use the [`qiskit.synthesis.synth_clifford_full()`](/api/qiskit/synthesis#qiskit.synthesis.synth_clifford_full "qiskit.synthesis.synth_clifford_full") function instead. - > * `decompose_cnotdihedral`: you should use the [`qiskit.synthesis.synth_cnotdihedral_full()`](/api/qiskit/synthesis#qiskit.synthesis.synth_cnotdihedral_full "qiskit.synthesis.synth_cnotdihedral_full") function instead. + > * `decompose_clifford`: you should use the [`qiskit.synthesis.synth_clifford_full()`](/api/qiskit/1.0/synthesis#qiskit.synthesis.synth_clifford_full "qiskit.synthesis.synth_clifford_full") function instead. + > * `decompose_cnotdihedral`: you should use the [`qiskit.synthesis.synth_cnotdihedral_full()`](/api/qiskit/1.0/synthesis#qiskit.synthesis.synth_cnotdihedral_full "qiskit.synthesis.synth_cnotdihedral_full") function instead. @@ -945,13 +945,13 @@ This guide is meant to complement the release notes and have a targeted advice f * Removed deprecated function `qiskit.transpiler.preset_passmanagers.common.get_vf2_call_limit`. Instead, use `get_vf2_limits()`. -* The implicit use of `approximation_degree!=1.0` by default in the [`generate_preset_pass_manager()`](/api/qiskit/transpiler_preset#qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager "qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager") function has been disabled. The previous default could cause undue and unexpected approximations, especially in workloads involving Trotterization or similar runs of operations that are close, but decidedly not equal, to the identity. +* The implicit use of `approximation_degree!=1.0` by default in the [`generate_preset_pass_manager()`](/api/qiskit/1.0/transpiler_preset#qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager "qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager") function has been disabled. The previous default could cause undue and unexpected approximations, especially in workloads involving Trotterization or similar runs of operations that are close, but decidedly not equal, to the identity. - This change brings the inner pass-manager generation defaults in line with [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile"), which was always the intention. See [#8595](https://github.com/Qiskit/qiskit/pull/8595) for more detail. + This change brings the inner pass-manager generation defaults in line with [`transpile()`](/api/qiskit/1.0/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile"), which was always the intention. See [#8595](https://github.com/Qiskit/qiskit/pull/8595) for more detail. -* Removed the deprecated `Unroller` class in `qiskit.transpiler.passes.basis`. This class was deprecated in Qiskit 0.45 and use of it can be replaced by the combination usage of [`BasisTranslator`](/api/qiskit/qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator") and [`UnrollCustomDefinitions`](/api/qiskit/qiskit.transpiler.passes.UnrollCustomDefinitions "qiskit.transpiler.passes.UnrollCustomDefinitions"). +* Removed the deprecated `Unroller` class in `qiskit.transpiler.passes.basis`. This class was deprecated in Qiskit 0.45 and use of it can be replaced by the combination usage of [`BasisTranslator`](/api/qiskit/1.0/qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator") and [`UnrollCustomDefinitions`](/api/qiskit/1.0/qiskit.transpiler.passes.UnrollCustomDefinitions "qiskit.transpiler.passes.UnrollCustomDefinitions"). - Note that [`BasisTranslator`](/api/qiskit/qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator") and [`UnrollCustomDefinitions`](/api/qiskit/qiskit.transpiler.passes.UnrollCustomDefinitions "qiskit.transpiler.passes.UnrollCustomDefinitions") take different arguments than `Unroller`, as they requires a `EquivalenceLibrary` object to be passed in. + Note that [`BasisTranslator`](/api/qiskit/1.0/qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator") and [`UnrollCustomDefinitions`](/api/qiskit/1.0/qiskit.transpiler.passes.UnrollCustomDefinitions "qiskit.transpiler.passes.UnrollCustomDefinitions") take different arguments than `Unroller`, as they requires a `EquivalenceLibrary` object to be passed in. Where previously `Unroller(basis_gates)` could be used, you can now use: @@ -966,24 +966,24 @@ This guide is meant to complement the release notes and have a targeted advice f translated = pm.run(circuit) ``` -* The deprecated `NoiseAdaptiveLayout` transpiler pass has been removed. It was marked as deprecated in Qiskit 0.46.0. This pass has been largely superseded by [`VF2Layout`](/api/qiskit/qiskit.transpiler.passes.VF2Layout "qiskit.transpiler.passes.VF2Layout") and [`VF2PostLayout`](/api/qiskit/qiskit.transpiler.passes.VF2PostLayout "qiskit.transpiler.passes.VF2PostLayout") which will set a layout based on the reported noise characteristics of a backend. Along with the pass, the `layout_method` plugin `"noise_adaptive"` has been removed. +* The deprecated `NoiseAdaptiveLayout` transpiler pass has been removed. It was marked as deprecated in Qiskit 0.46.0. This pass has been largely superseded by [`VF2Layout`](/api/qiskit/1.0/qiskit.transpiler.passes.VF2Layout "qiskit.transpiler.passes.VF2Layout") and [`VF2PostLayout`](/api/qiskit/1.0/qiskit.transpiler.passes.VF2PostLayout "qiskit.transpiler.passes.VF2PostLayout") which will set a layout based on the reported noise characteristics of a backend. Along with the pass, the `layout_method` plugin `"noise_adaptive"` has been removed. -* The deprecated `CrosstalkAdaptiveSchedule` transpiler pass has been removed. It was marked as deprecated in Qiskit 0.46.0. This pass was not usable any longer because its internal operation was dependent on custom properties being set in the [`BackendProperties`](/api/qiskit/qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") payload of a [`BackendV1`](/api/qiskit/qiskit.providers.BackendV1 "qiskit.providers.BackendV1") instance. As no backends are setting these fields, the pass was removed. If you depend on the pass for a custom workflow you can use the version in Qiskit 0.46.x. +* The deprecated `CrosstalkAdaptiveSchedule` transpiler pass has been removed. It was marked as deprecated in Qiskit 0.46.0. This pass was not usable any longer because its internal operation was dependent on custom properties being set in the [`BackendProperties`](/api/qiskit/1.0/qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") payload of a [`BackendV1`](/api/qiskit/1.0/qiskit.providers.BackendV1 "qiskit.providers.BackendV1") instance. As no backends are setting these fields, the pass was removed. If you depend on the pass for a custom workflow you can use the version in Qiskit 0.46.x. * Removed the `qiskit.transpiler.synthesis` module, which has been deprecated since the 0.46 release. The following objects have been moved: - * `qiskit.transpiler.synthesis.aqc` has been moved to [`qiskit.synthesis.unitary.aqc`](/api/qiskit/qiskit.synthesis.unitary.aqc#module-qiskit.synthesis.unitary.aqc "qiskit.synthesis.unitary.aqc") (except of `qiskit.synthesis.unitary.aqc.AQCSynthesisPlugin`). + * `qiskit.transpiler.synthesis.aqc` has been moved to [`qiskit.synthesis.unitary.aqc`](/api/qiskit/1.0/qiskit.synthesis.unitary.aqc#module-qiskit.synthesis.unitary.aqc "qiskit.synthesis.unitary.aqc") (except of `qiskit.synthesis.unitary.aqc.AQCSynthesisPlugin`). * `qiskit.synthesis.unitary.aqc.AQCSynthesisPlugin` has been moved to `qiskit.transpiler.passes.synthesis.AQCSynthesisPlugin`. - * `qiskit.transpiler.synthesis.graysynth()` has been moved to [`qiskit.synthesis.synth_cnot_phase_aam()`](/api/qiskit/synthesis#qiskit.synthesis.synth_cnot_phase_aam "qiskit.synthesis.synth_cnot_phase_aam"). - * `qiskit.transpiler.synthesis.cnot_synth()` has been moved to [`qiskit.synthesis.synth_cnot_count_full_pmh()`](/api/qiskit/synthesis#qiskit.synthesis.synth_cnot_count_full_pmh "qiskit.synthesis.synth_cnot_count_full_pmh"). + * `qiskit.transpiler.synthesis.graysynth()` has been moved to [`qiskit.synthesis.synth_cnot_phase_aam()`](/api/qiskit/1.0/synthesis#qiskit.synthesis.synth_cnot_phase_aam "qiskit.synthesis.synth_cnot_phase_aam"). + * `qiskit.transpiler.synthesis.cnot_synth()` has been moved to [`qiskit.synthesis.synth_cnot_count_full_pmh()`](/api/qiskit/1.0/synthesis#qiskit.synthesis.synth_cnot_count_full_pmh "qiskit.synthesis.synth_cnot_count_full_pmh"). -* The `target` keyword alias when calling [`TwoQubitBasisDecomposer`](/api/qiskit/qiskit.synthesis.TwoQubitBasisDecomposer "qiskit.synthesis.TwoQubitBasisDecomposer") instances as functions has been removed following its deprecation in Qiskit 0.40.0. You should pass the argument positionally as the first argument, or use the new name `unitary`. +* The `target` keyword alias when calling [`TwoQubitBasisDecomposer`](/api/qiskit/1.0/qiskit.synthesis.TwoQubitBasisDecomposer "qiskit.synthesis.TwoQubitBasisDecomposer") instances as functions has been removed following its deprecation in Qiskit 0.40.0. You should pass the argument positionally as the first argument, or use the new name `unitary`. -* The specialized transpiler pass `LinearFunctionsSynthesis` has been removed following its deprecation in Qiskit 0.40.0. Since its deprecation it just has been a very thin wrapper around [`HighLevelSynthesis`](/api/qiskit/qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis"), which you should use instead. +* The specialized transpiler pass `LinearFunctionsSynthesis` has been removed following its deprecation in Qiskit 0.40.0. Since its deprecation it just has been a very thin wrapper around [`HighLevelSynthesis`](/api/qiskit/1.0/qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis"), which you should use instead. -* The import path `qiskit.transpiler.passes.scheduling.calibration_creators` is removed. The transpiler passes it housed, [`RZXCalibrationBuilder`](/api/qiskit/qiskit.transpiler.passes.RZXCalibrationBuilder "qiskit.transpiler.passes.RZXCalibrationBuilder") and [`RZXCalibrationBuilderNoEcho`](/api/qiskit/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho "qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho") can be imported directly from [`qiskit.transpiler.passes`](/api/qiskit/transpiler_passes#module-qiskit.transpiler.passes "qiskit.transpiler.passes"). +* The import path `qiskit.transpiler.passes.scheduling.calibration_creators` is removed. The transpiler passes it housed, [`RZXCalibrationBuilder`](/api/qiskit/1.0/qiskit.transpiler.passes.RZXCalibrationBuilder "qiskit.transpiler.passes.RZXCalibrationBuilder") and [`RZXCalibrationBuilderNoEcho`](/api/qiskit/1.0/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho "qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho") can be imported directly from [`qiskit.transpiler.passes`](/api/qiskit/1.0/transpiler_passes#module-qiskit.transpiler.passes "qiskit.transpiler.passes"). -* The import path `qiskit.transpiler.passes.scheduling.rzx_templates` is removed. You should import [`rzx_templates()`](/api/qiskit/transpiler_passes#qiskit.transpiler.passes.rzx_templates "qiskit.transpiler.passes.rzx_templates") from [`qiskit.transpiler.passes`](/api/qiskit/transpiler_passes#module-qiskit.transpiler.passes "qiskit.transpiler.passes") directly. +* The import path `qiskit.transpiler.passes.scheduling.rzx_templates` is removed. You should import [`rzx_templates()`](/api/qiskit/1.0/transpiler_passes#qiskit.transpiler.passes.rzx_templates "qiskit.transpiler.passes.rzx_templates") from [`qiskit.transpiler.passes`](/api/qiskit/1.0/transpiler_passes#module-qiskit.transpiler.passes "qiskit.transpiler.passes") directly. * A pattern for the pass piepline construction was upgraded. The syntactic sugar shown below for instantiation of flow controller was removed. @@ -1028,7 +1028,7 @@ This guide is meant to complement the release notes and have a targeted advice f The task pipeline in a flow controller is frozen, and it must be passed when the controller instance is created. -* Removed the `passess` methods of [`PassManager`](/api/qiskit/qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") and [`StagedPassManager`](/api/qiskit/qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager") that returned a representation of included passes in the form of list of dictionaries. However, this format doesn’t efficiently represent more complicated pass pipeline, which may include conditional branching and nested conditions. Instead of using this representation, please use following pattern +* Removed the `passess` methods of [`PassManager`](/api/qiskit/1.0/qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") and [`StagedPassManager`](/api/qiskit/1.0/qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager") that returned a representation of included passes in the form of list of dictionaries. However, this format doesn’t efficiently represent more complicated pass pipeline, which may include conditional branching and nested conditions. Instead of using this representation, please use following pattern ```python pm = PassManager(...) @@ -1037,7 +1037,7 @@ This guide is meant to complement the release notes and have a targeted advice f This directly returns a linearized base task instances in tuple format. -* The `max_iteration` argument was removed from [`PassManager.append()`](/api/qiskit/qiskit.transpiler.PassManager#append "qiskit.transpiler.PassManager.append") and [`PassManager.replace()`](/api/qiskit/qiskit.transpiler.PassManager#replace "qiskit.transpiler.PassManager.replace"). +* The `max_iteration` argument was removed from [`PassManager.append()`](/api/qiskit/1.0/qiskit.transpiler.PassManager#append "qiskit.transpiler.PassManager.append") and [`PassManager.replace()`](/api/qiskit/1.0/qiskit.transpiler.PassManager#replace "qiskit.transpiler.PassManager.replace"). * The following legacy classes were removed from the pass manager and transpiler modules following their deprecation in Qiskit 0.46: @@ -1055,7 +1055,7 @@ This guide is meant to complement the release notes and have a targeted advice f * The deprecated module `qiskit.visualization.qcstyle` has been removed. This module has been marked as deprecated since Qiskit 0.39.0. Instead you should use the `qiskit.visualization.circuit.qcstyle`. -* The deprecated support for passing a [`QuasiDistribution`](/api/qiskit/qiskit.result.QuasiDistribution "qiskit.result.QuasiDistribution"), [`ProbDistribution`](/api/qiskit/qiskit.result.ProbDistribution "qiskit.result.ProbDistribution"), or a distribution dictionary to the `data` argument of the [`plot_histogram()`](/api/qiskit/qiskit.visualization.plot_histogram "qiskit.visualization.plot_histogram") visualization has been removed. This functionality was marked as deprecated in the Qiskit 0.39.0 release (2022-10). Instead if you would like to plot a histogram from a [`QuasiDistribution`](/api/qiskit/qiskit.result.QuasiDistribution "qiskit.result.QuasiDistribution"), [`ProbDistribution`](/api/qiskit/qiskit.result.ProbDistribution "qiskit.result.ProbDistribution"), or a distribution dictionary you should use the [`plot_distribution()`](/api/qiskit/qiskit.visualization.plot_distribution "qiskit.visualization.plot_distribution") function instead. +* The deprecated support for passing a [`QuasiDistribution`](/api/qiskit/1.0/qiskit.result.QuasiDistribution "qiskit.result.QuasiDistribution"), [`ProbDistribution`](/api/qiskit/1.0/qiskit.result.ProbDistribution "qiskit.result.ProbDistribution"), or a distribution dictionary to the `data` argument of the [`plot_histogram()`](/api/qiskit/1.0/qiskit.visualization.plot_histogram "qiskit.visualization.plot_histogram") visualization has been removed. This functionality was marked as deprecated in the Qiskit 0.39.0 release (2022-10). Instead if you would like to plot a histogram from a [`QuasiDistribution`](/api/qiskit/1.0/qiskit.result.QuasiDistribution "qiskit.result.QuasiDistribution"), [`ProbDistribution`](/api/qiskit/1.0/qiskit.result.ProbDistribution "qiskit.result.ProbDistribution"), or a distribution dictionary you should use the [`plot_distribution()`](/api/qiskit/1.0/qiskit.visualization.plot_distribution "qiskit.visualization.plot_distribution") function instead. * The `link_interval_dt` key of `QiskitTimelineStyle` has been removed. You should use the new name `link_interval_percent`. @@ -1069,7 +1069,7 @@ This guide is meant to complement the release notes and have a targeted advice f * Pulse jobs are no longer supported in fake backends, following the deprecation and removal of the underlying simulation functionality in Aer. For pulse-level simulation, outside the context of circuit objects, consider using a special-purpose library such as [Qiskit Dynamics](https://qiskit.org/ecosystem/dynamics/). -* Qiskit’s `execute()` function is removed. This function served as a high-level wrapper around transpiling a circuit with some transpile options and running it on a backend with some run options. To do the same thing, you can explicitly use the [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function (with appropriate transpile options) followed by `backend.run()` (with appropriate run options). +* Qiskit’s `execute()` function is removed. This function served as a high-level wrapper around transpiling a circuit with some transpile options and running it on a backend with some run options. To do the same thing, you can explicitly use the [`transpile()`](/api/qiskit/1.0/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function (with appropriate transpile options) followed by `backend.run()` (with appropriate run options). For example, instead of running: @@ -1086,7 +1086,7 @@ This guide is meant to complement the release notes and have a targeted advice f job = backend.run(new_circuit) ``` - Alternatively, the `Sampler` primitive is semantically equivalent to the deprecated `execute()` function. The class [`BackendSampler`](/api/qiskit/qiskit.primitives.BackendSampler "qiskit.primitives.BackendSampler") is a generic wrapper for backends that do not support primitives: + Alternatively, the `Sampler` primitive is semantically equivalent to the deprecated `execute()` function. The class [`BackendSampler`](/api/qiskit/1.0/qiskit.primitives.BackendSampler "qiskit.primitives.BackendSampler") is a generic wrapper for backends that do not support primitives: ```python from qiskit.primitives import BackendSampler @@ -1098,17 +1098,17 @@ This guide is meant to complement the release notes and have a targeted advice f * Removed the deprecated module `qiskit.tools.jupyter` which previously included Jupyter magics and widgets for interactively visualizing some data from Qiskit. This module was deprecated in Qiskit 0.46.0. Most of this functionality was directly tied to the legacy `qiskit-ibmq-provider` package and was no longer valid so the module was removed. Similar functionality is available from the `qiskit_ibm_provider.jupyter` module in the [qiskit-ibm-provider](https://github.com/Qiskit/qiskit-ibm-provider) package. -* Removed the deprecated module `qiskit.tools.monitor` which previously included tools for tracking [`JobV1`](/api/qiskit/qiskit.providers.JobV1 "qiskit.providers.JobV1") job instances, primarily from the legacy `qiskit-ibm-provider` package. This module was marked as deprecated in Qiskit 0.46.0. It is being removed because it was directly tied to the legacy `qiskit-ibm-provider` package. +* Removed the deprecated module `qiskit.tools.monitor` which previously included tools for tracking [`JobV1`](/api/qiskit/1.0/qiskit.providers.JobV1 "qiskit.providers.JobV1") job instances, primarily from the legacy `qiskit-ibm-provider` package. This module was marked as deprecated in Qiskit 0.46.0. It is being removed because it was directly tied to the legacy `qiskit-ibm-provider` package. -* Removed the deprecated import path `qiskit.test.mock` which previously was used to redirect imports for the mock backends to their newer location in the [`qiskit.providers.fake_provider`](/api/qiskit/providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider"). This module was marked as deprecated in Qiskit 0.37.0. If you were using this module you should update your imports from `qiskit.test.mock` to [`qiskit.providers.fake_provider`](/api/qiskit/providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider") instead. +* Removed the deprecated import path `qiskit.test.mock` which previously was used to redirect imports for the mock backends to their newer location in the [`qiskit.providers.fake_provider`](/api/qiskit/1.0/providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider"). This module was marked as deprecated in Qiskit 0.37.0. If you were using this module you should update your imports from `qiskit.test.mock` to [`qiskit.providers.fake_provider`](/api/qiskit/1.0/providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider") instead. * The `qiskit.test` module is no longer a public module. This was never intended to be public, nor used outside of Qiskit’s own test suite. All functionality was specific to Qiskit and no alternative is provided; if you needed similar functionality, you should include it in your own test harnesses. -* The deprecated `qiskit.tools.visualization` module has removed. This module was deprecated in the Qiskit 0.46.0 release. This module was a legacy redirect from the original location of Qiskit’s visualization module and was moved to [`qiskit.visualization`](/api/qiskit/visualization#module-qiskit.visualization "qiskit.visualization") in Qiskit 0.8.0. If you’re still using this path you can just update your imports from `qiskit.tools.visualization` to [`qiskit.visualization`](/api/qiskit/visualization#module-qiskit.visualization "qiskit.visualization"). +* The deprecated `qiskit.tools.visualization` module has removed. This module was deprecated in the Qiskit 0.46.0 release. This module was a legacy redirect from the original location of Qiskit’s visualization module and was moved to [`qiskit.visualization`](/api/qiskit/1.0/visualization#module-qiskit.visualization "qiskit.visualization") in Qiskit 0.8.0. If you’re still using this path you can just update your imports from `qiskit.tools.visualization` to [`qiskit.visualization`](/api/qiskit/1.0/visualization#module-qiskit.visualization "qiskit.visualization"). * The deprecated `qiskit.tools.events` module and the corresponding `qiskit.tools.progressbar` utility it exposed has been removed. It was deprecated in the Qiskit 0.46.0 release. This module’s functionality was not widely used and better covered by dedicated packages such as [tqdm](https://github.com/tqdm/tqdm). -* The `qiskit.tools` module has been removed. This module was deprecated in Qiskit 0.46.0. All the contents from this module have been removed except for the `qiskit.tools.parallel_map` function which now can be used from [`qiskit.utils.parallel_map()`](/api/qiskit/utils#qiskit.utils.parallel_map "qiskit.utils.parallel_map") instead. +* The `qiskit.tools` module has been removed. This module was deprecated in Qiskit 0.46.0. All the contents from this module have been removed except for the `qiskit.tools.parallel_map` function which now can be used from [`qiskit.utils.parallel_map()`](/api/qiskit/1.0/utils#qiskit.utils.parallel_map "qiskit.utils.parallel_map") instead. @@ -1124,27 +1124,27 @@ This guide is meant to complement the release notes and have a targeted advice f * Fixed the return of improper measurement schedules when only a subset of qubits was requested. Previously, a measurement schedule for all qubits would be returned. -* Fixed an issue in the `text` circuit drawer when displaying operations that were not [`circuit.instruction.Instruction`](/api/qiskit/qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") class. These operations would cause the drawer to fail. Examples were [`Clifford`](/api/qiskit/qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") and [`AnnotatedOperation`](/api/qiskit/qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). +* Fixed an issue in the `text` circuit drawer when displaying operations that were not [`circuit.instruction.Instruction`](/api/qiskit/1.0/qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") class. These operations would cause the drawer to fail. Examples were [`Clifford`](/api/qiskit/1.0/qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") and [`AnnotatedOperation`](/api/qiskit/1.0/qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). -* Fixed an issue with the [`SetLayout`](/api/qiskit/qiskit.transpiler.passes.SetLayout "qiskit.transpiler.passes.SetLayout") transpiler pass where an invalid integer list input that contained duplicate entries which would result in an invalid [`Layout`](/api/qiskit/qiskit.transpiler.Layout "qiskit.transpiler.Layout") being generated and subsequent transpiler passes would fail with a cryptic error. This is now caught when [`SetLayout.run()`](/api/qiskit/qiskit.transpiler.passes.SetLayout#run "qiskit.transpiler.passes.SetLayout.run") is called an [`InvalidLayoutError`](/api/qiskit/transpiler#qiskit.transpiler.InvalidLayoutError "qiskit.transpiler.InvalidLayoutError") error will be raised indicating there are duplicate entries in the integer list. +* Fixed an issue with the [`SetLayout`](/api/qiskit/1.0/qiskit.transpiler.passes.SetLayout "qiskit.transpiler.passes.SetLayout") transpiler pass where an invalid integer list input that contained duplicate entries which would result in an invalid [`Layout`](/api/qiskit/1.0/qiskit.transpiler.Layout "qiskit.transpiler.Layout") being generated and subsequent transpiler passes would fail with a cryptic error. This is now caught when [`SetLayout.run()`](/api/qiskit/1.0/qiskit.transpiler.passes.SetLayout#run "qiskit.transpiler.passes.SetLayout.run") is called an [`InvalidLayoutError`](/api/qiskit/1.0/transpiler#qiskit.transpiler.InvalidLayoutError "qiskit.transpiler.InvalidLayoutError") error will be raised indicating there are duplicate entries in the integer list. -* QPY (using [`qpy.dump()`](/api/qiskit/qpy#qiskit.qpy.dump "qiskit.qpy.dump") and [`qpy.load()`](/api/qiskit/qpy#qiskit.qpy.load "qiskit.qpy.load")) will now correctly serialize and deserialize quantum circuits with annotated operations ([`AnnotatedOperation`](/api/qiskit/qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). +* QPY (using [`qpy.dump()`](/api/qiskit/1.0/qpy#qiskit.qpy.dump "qiskit.qpy.dump") and [`qpy.load()`](/api/qiskit/1.0/qpy#qiskit.qpy.load "qiskit.qpy.load")) will now correctly serialize and deserialize quantum circuits with annotated operations ([`AnnotatedOperation`](/api/qiskit/1.0/qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")). -* Calling [`copy()`](/api/qiskit/qiskit.circuit.QuantumCircuit#copy "qiskit.circuit.QuantumCircuit.copy") or [`copy_empty_like()`](/api/qiskit/qiskit.circuit.QuantumCircuit#copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like") on a `BlueprintCircuit` will now correctly propagate the [`global_phase`](/api/qiskit/qiskit.circuit.QuantumCircuit#global_phase "qiskit.circuit.QuantumCircuit.global_phase") to the copy. Previously, the global phase would always be zero after the copy. +* Calling [`copy()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#copy "qiskit.circuit.QuantumCircuit.copy") or [`copy_empty_like()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like") on a `BlueprintCircuit` will now correctly propagate the [`global_phase`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#global_phase "qiskit.circuit.QuantumCircuit.global_phase") to the copy. Previously, the global phase would always be zero after the copy. -* [`QuantumCircuit.compose()`](/api/qiskit/qiskit.circuit.QuantumCircuit#compose "qiskit.circuit.QuantumCircuit.compose") will now correctly raise a [`CircuitError`](/api/qiskit/circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") when there are duplicates in the `qubits` or `clbits` arguments. +* [`QuantumCircuit.compose()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#compose "qiskit.circuit.QuantumCircuit.compose") will now correctly raise a [`CircuitError`](/api/qiskit/1.0/circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") when there are duplicates in the `qubits` or `clbits` arguments. -* QPY (using [`qpy.dump()`](/api/qiskit/qpy#qiskit.qpy.dump "qiskit.qpy.dump") and [`qpy.load()`](/api/qiskit/qpy#qiskit.qpy.load "qiskit.qpy.load")) will now correctly serialize and deserialize quantum circuits with Clifford operators ([`Clifford`](/api/qiskit/qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford")). +* QPY (using [`qpy.dump()`](/api/qiskit/1.0/qpy#qiskit.qpy.dump "qiskit.qpy.dump") and [`qpy.load()`](/api/qiskit/1.0/qpy#qiskit.qpy.load "qiskit.qpy.load")) will now correctly serialize and deserialize quantum circuits with Clifford operators ([`Clifford`](/api/qiskit/1.0/qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford")). -* Fixed an issue in the `mpl` circuit drawer where the text would print beyond the end of the box for a [`SwitchCaseOp`](/api/qiskit/qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp") if the default case was empty. +* Fixed an issue in the `mpl` circuit drawer where the text would print beyond the end of the box for a [`SwitchCaseOp`](/api/qiskit/1.0/qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp") if the default case was empty. -* The qubit-argument broadcasting of [`QuantumCircuit.delay()`](/api/qiskit/qiskit.circuit.QuantumCircuit#delay "qiskit.circuit.QuantumCircuit.delay") now correctly produces individual [`Delay`](/api/qiskit/qiskit.circuit.Delay "qiskit.circuit.Delay") instructions for each qubit, as intended. Previously, when given certain iterables (such as [`set`](https://docs.python.org/3/library/stdtypes.html#set "(in Python v3.12)")s), it would instead silently produce an invalid circuit that might fail in unusual locations. +* The qubit-argument broadcasting of [`QuantumCircuit.delay()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#delay "qiskit.circuit.QuantumCircuit.delay") now correctly produces individual [`Delay`](/api/qiskit/1.0/qiskit.circuit.Delay "qiskit.circuit.Delay") instructions for each qubit, as intended. Previously, when given certain iterables (such as [`set`](https://docs.python.org/3/library/stdtypes.html#set "(in Python v3.12)")s), it would instead silently produce an invalid circuit that might fail in unusual locations. -* Fixed an issue when using [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or running a preset pass manager (such as generated by [`generate_preset_pass_manager()`](/api/qiskit/transpiler_preset#qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager "qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager")) when targeting a backend that has disjoint connectivity adding extra barriers to the output [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). In some cases several single qubit [`Barrier`](/api/qiskit/qiskit.circuit.library.Barrier "qiskit.circuit.library.Barrier") directives would be included in the output circuit right before any final measurements in the circuit. This was internal state generated by the internal processing for disjoint connectivity that was incorrectly being added into the output circuit. Fixed [#11649](https://github.com/Qiskit/qiskit/issues/11649) +* Fixed an issue when using [`transpile()`](/api/qiskit/1.0/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or running a preset pass manager (such as generated by [`generate_preset_pass_manager()`](/api/qiskit/1.0/transpiler_preset#qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager "qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager")) when targeting a backend that has disjoint connectivity adding extra barriers to the output [`QuantumCircuit`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). In some cases several single qubit [`Barrier`](/api/qiskit/1.0/qiskit.circuit.library.Barrier "qiskit.circuit.library.Barrier") directives would be included in the output circuit right before any final measurements in the circuit. This was internal state generated by the internal processing for disjoint connectivity that was incorrectly being added into the output circuit. Fixed [#11649](https://github.com/Qiskit/qiskit/issues/11649) -* Fixed an error when a user tries to load calibration data of a gate from a [`Target`](/api/qiskit/qiskit.transpiler.Target "qiskit.transpiler.Target") in a particular situation. This occurs when the backend reports only partial calibration data, for example referencing a waveform pulse in a command definition but not including that waveform pulse in the pulse library. In this situation, the Qiskit pulse object could not be built, resulting in a failure to build the pulse schedule for the calibration. Now when calibration data is incomplete the [`Target`](/api/qiskit/qiskit.transpiler.Target "qiskit.transpiler.Target") treats it as equivalent to no calibration being reported at all and does not raise an exception. +* Fixed an error when a user tries to load calibration data of a gate from a [`Target`](/api/qiskit/1.0/qiskit.transpiler.Target "qiskit.transpiler.Target") in a particular situation. This occurs when the backend reports only partial calibration data, for example referencing a waveform pulse in a command definition but not including that waveform pulse in the pulse library. In this situation, the Qiskit pulse object could not be built, resulting in a failure to build the pulse schedule for the calibration. Now when calibration data is incomplete the [`Target`](/api/qiskit/1.0/qiskit.transpiler.Target "qiskit.transpiler.Target") treats it as equivalent to no calibration being reported at all and does not raise an exception. -* The [`Operator.power()`](/api/qiskit/qiskit.quantum_info.Operator#power "qiskit.quantum_info.Operator.power") method now works with floating-point exponents, matching the documented description. +* The [`Operator.power()`](/api/qiskit/1.0/qiskit.quantum_info.Operator#power "qiskit.quantum_info.Operator.power") method now works with floating-point exponents, matching the documented description. * Fixed an issue with the `OptimizeSwapBeforeMeasure` pass where it would incorrectly optimize circuits involving swap and measure instructions. For example: @@ -1190,23 +1190,23 @@ This guide is meant to complement the release notes and have a targeted advice f 0 0 ``` -* Fixed an issue with the QPY serialization when a [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") contained multiple custom instructions instances that have the same [`name`](/api/qiskit/qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") attribute. In QPY format versions before [Version 11](/api/qiskit/qpy#qpy-version-11) the QPY payload did not differentiate between these instances and would only serialize the properties of the first instance in a circuit. This could potentially cause an incorrect deserialization if the other properties of the custom instruction were different but the names were the same. This has been fixed in QPY [Version 11](/api/qiskit/qpy#qpy-version-11) so that each instance of a custom instruction is serialized individually and there will no longer be a potential conflict with overlapping names. Fixes [#8941](https://github.com/Qiskit/qiskit/issues/8941). +* Fixed an issue with the QPY serialization when a [`QuantumCircuit`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") contained multiple custom instructions instances that have the same [`name`](/api/qiskit/1.0/qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") attribute. In QPY format versions before [Version 11](/api/qiskit/1.0/qpy#qpy-version-11) the QPY payload did not differentiate between these instances and would only serialize the properties of the first instance in a circuit. This could potentially cause an incorrect deserialization if the other properties of the custom instruction were different but the names were the same. This has been fixed in QPY [Version 11](/api/qiskit/1.0/qpy#qpy-version-11) so that each instance of a custom instruction is serialized individually and there will no longer be a potential conflict with overlapping names. Fixes [#8941](https://github.com/Qiskit/qiskit/issues/8941). -* Fixed an issue with the [`qpy.dump()`](/api/qiskit/qpy#qiskit.qpy.dump "qiskit.qpy.dump") function where, when the `use_symengine` flag was set to a truthy object that evaluated to `True` but was not actually the boolean `True`, the generated QPY payload would be corrupt. For example, if you set `use_symengine` to [`HAS_SYMENGINE`](/api/qiskit/utils#qiskit.utils.optionals.HAS_SYMENGINE "qiskit.utils.optionals.HAS_SYMENGINE"), this object evaluates to `True` when cast as a bool, but isn’t actually `True`. +* Fixed an issue with the [`qpy.dump()`](/api/qiskit/1.0/qpy#qiskit.qpy.dump "qiskit.qpy.dump") function where, when the `use_symengine` flag was set to a truthy object that evaluated to `True` but was not actually the boolean `True`, the generated QPY payload would be corrupt. For example, if you set `use_symengine` to [`HAS_SYMENGINE`](/api/qiskit/1.0/utils#qiskit.utils.optionals.HAS_SYMENGINE "qiskit.utils.optionals.HAS_SYMENGINE"), this object evaluates to `True` when cast as a bool, but isn’t actually `True`. -* Fix a bug in the [`StabilizerState`](/api/qiskit/qiskit.quantum_info.StabilizerState "qiskit.quantum_info.StabilizerState") string representation. +* Fix a bug in the [`StabilizerState`](/api/qiskit/1.0/qiskit.quantum_info.StabilizerState "qiskit.quantum_info.StabilizerState") string representation. -* A bug where [`convert_to_target()`](/api/qiskit/qiskit.providers.convert_to_target "qiskit.providers.convert_to_target") and [`BackendV2Converter`](/api/qiskit/qiskit.providers.BackendV2Converter "qiskit.providers.BackendV2Converter") raised an unexpected error was solved. The bug occurred when the backend to convert included calibrations for a gate that didn’t have a definition in the backend properties. Such gate is now broadcast to all qubits as an ideal error-free instruction, even when calibrations for a finite set of qubits are reported. +* A bug where [`convert_to_target()`](/api/qiskit/1.0/qiskit.providers.convert_to_target "qiskit.providers.convert_to_target") and [`BackendV2Converter`](/api/qiskit/1.0/qiskit.providers.BackendV2Converter "qiskit.providers.BackendV2Converter") raised an unexpected error was solved. The bug occurred when the backend to convert included calibrations for a gate that didn’t have a definition in the backend properties. Such gate is now broadcast to all qubits as an ideal error-free instruction, even when calibrations for a finite set of qubits are reported. -* Fixed an issue with the [`circuit_drawer()`](/api/qiskit/qiskit.visualization.circuit_drawer "qiskit.visualization.circuit_drawer") function and [`QuantumCircuit.draw()`](/api/qiskit/qiskit.circuit.QuantumCircuit#draw "qiskit.circuit.QuantumCircuit.draw") method when loading a matplotlib style via the user configuration file. +* Fixed an issue with the [`circuit_drawer()`](/api/qiskit/1.0/qiskit.visualization.circuit_drawer "qiskit.visualization.circuit_drawer") function and [`QuantumCircuit.draw()`](/api/qiskit/1.0/qiskit.circuit.QuantumCircuit#draw "qiskit.circuit.QuantumCircuit.draw") method when loading a matplotlib style via the user configuration file. -* [`InstructionDurations.from_backend()`](/api/qiskit/qiskit.transpiler.InstructionDurations#from_backend "qiskit.transpiler.InstructionDurations.from_backend") now returns an instance of any subclass of [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") instead of the base class. +* [`InstructionDurations.from_backend()`](/api/qiskit/1.0/qiskit.transpiler.InstructionDurations#from_backend "qiskit.transpiler.InstructionDurations.from_backend") now returns an instance of any subclass of [`InstructionDurations`](/api/qiskit/1.0/qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") instead of the base class. -* The [`UnitarySynthesis`](/api/qiskit/qiskit.transpiler.passes.UnitarySynthesis "qiskit.transpiler.passes.UnitarySynthesis") transpiler pass will now generate an error on initialization when a nonexistent synthesis plugin is specified, rather than waiting until runtime to raise. Fixed [#11355](https://github.com/Qiskit/qiskit/issues/11355). +* The [`UnitarySynthesis`](/api/qiskit/1.0/qiskit.transpiler.passes.UnitarySynthesis "qiskit.transpiler.passes.UnitarySynthesis") transpiler pass will now generate an error on initialization when a nonexistent synthesis plugin is specified, rather than waiting until runtime to raise. Fixed [#11355](https://github.com/Qiskit/qiskit/issues/11355). -* The OpenQASM 3 exporters [`qasm3.dump()`](/api/qiskit/qasm3#qiskit.qasm3.dump "qiskit.qasm3.dump") and [`dumps()`](/api/qiskit/qasm3#qiskit.qasm3.dumps "qiskit.qasm3.dumps") will now correctly output files claiming to be version `3.0` rather than the unqualified `3`, since the OpenQASM 3 project has now standardized on versioning. +* The OpenQASM 3 exporters [`qasm3.dump()`](/api/qiskit/1.0/qasm3#qiskit.qasm3.dump "qiskit.qasm3.dump") and [`dumps()`](/api/qiskit/1.0/qasm3#qiskit.qasm3.dumps "qiskit.qasm3.dumps") will now correctly output files claiming to be version `3.0` rather than the unqualified `3`, since the OpenQASM 3 project has now standardized on versioning. -* The parametric form of [`XXPlusYYGate`](/api/qiskit/qiskit.circuit.library.XXPlusYYGate "qiskit.circuit.library.XXPlusYYGate") and [`XXMinusYYGate`](/api/qiskit/qiskit.circuit.library.XXMinusYYGate "qiskit.circuit.library.XXMinusYYGate") returned from `get_standard_gate_name_mapping()` now correctly includes the $\beta$ parameter as well as the initial $\theta$ rotation. +* The parametric form of [`XXPlusYYGate`](/api/qiskit/1.0/qiskit.circuit.library.XXPlusYYGate "qiskit.circuit.library.XXPlusYYGate") and [`XXMinusYYGate`](/api/qiskit/1.0/qiskit.circuit.library.XXMinusYYGate "qiskit.circuit.library.XXMinusYYGate") returned from `get_standard_gate_name_mapping()` now correctly includes the $\beta$ parameter as well as the initial $\theta$ rotation. -* The [`TemplateOptimization`](/api/qiskit/qiskit.transpiler.passes.TemplateOptimization "qiskit.transpiler.passes.TemplateOptimization") pass will now return parametric expressions using the native symbolic expression format of [`ParameterExpression`](/api/qiskit/qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression"), rather than always using Sympy. For most supported platforms, this means that the expressions will be Symengine objects. Previously, the pass could return mismatched objects, which could lead to later failures in parameter-handling code. +* The [`TemplateOptimization`](/api/qiskit/1.0/qiskit.transpiler.passes.TemplateOptimization "qiskit.transpiler.passes.TemplateOptimization") pass will now return parametric expressions using the native symbolic expression format of [`ParameterExpression`](/api/qiskit/1.0/qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression"), rather than always using Sympy. For most supported platforms, this means that the expressions will be Symengine objects. Previously, the pass could return mismatched objects, which could lead to later failures in parameter-handling code. diff --git a/docs/api/qiskit/release-notes/1.1.mdx b/docs/api/qiskit/release-notes/1.1.mdx new file mode 100644 index 00000000000..fc27be34c07 --- /dev/null +++ b/docs/api/qiskit/release-notes/1.1.mdx @@ -0,0 +1,904 @@ +--- +title: Qiskit SDK 1.1 release notes +description: Changes made in Qiskit SDK 1.1 +in_page_toc_max_heading_level: 3 +--- + + + + + +# Qiskit SDK 1.1 release notes + + + + + +## 1.1.0 + + + +### Prelude + +The Qiskit 1.1.0 release is a minor feature release that includes a myriad of new feature and bugfixes. The highlights for this release are: + +> * Support for typed classical variables has been added to Qiskit’s [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). These classical variables can be specified as inputs or as scoped variables in a [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") where they e.g. store the output of qubit measurements or target control-flow operations. Support for e.g. setting gate parameters or output variables will be added in the future. +> +> * The default two qubit synthesis methods that are used internally by the transpiler in the [`UnitarySynthesis`](/api/qiskit/qiskit.transpiler.passes.UnitarySynthesis "qiskit.transpiler.passes.UnitarySynthesis") pass have been re-implemented in Rust. This yields significant runtime speedups when decomposing two qubit unitary matrices. As a consequence, the runtime of transpilation with optimization level 3 was significantly improved where running [`UnitarySynthesis`](/api/qiskit/qiskit.transpiler.passes.UnitarySynthesis "qiskit.transpiler.passes.UnitarySynthesis") incurred a large runtime overhead historically. This release also starts running [`UnitarySynthesis`](/api/qiskit/qiskit.transpiler.passes.UnitarySynthesis "qiskit.transpiler.passes.UnitarySynthesis") as part of the optimization stage in optimization level 2 because of these runtime performance improvements. +> +> Additionally, the numeric methods used in [`Isometry`](/api/qiskit/qiskit.circuit.library.Isometry "qiskit.circuit.library.Isometry") have been moved to Rust, enabling large runtime speed-ups in particular for controlled unitary gate synthesis. The decomposition for multi-controlled :class:.XGate\` and [`PhaseGate`](/api/qiskit/qiskit.circuit.library.PhaseGate "qiskit.circuit.library.PhaseGate") has been improved resulting in a reduction in the number of gates used in the synthesis by more than two orders of magnitude. +> +> * A number of new transpiler passes have been introduced to Qiskit that yield significant runtime speedups while also decreasing the size of the transpiled quantum circuits in many cases. Specifically, [`ElidePermutations`](/api/qiskit/qiskit.transpiler.passes.ElidePermutations "qiskit.transpiler.passes.ElidePermutations") and [`StarPreRouting`](/api/qiskit/qiskit.transpiler.passes.StarPreRouting "qiskit.transpiler.passes.StarPreRouting") have been demonstrated to have a significant impact on the routing output quality and runtime and [`RemoveFinalReset`](/api/qiskit/qiskit.transpiler.passes.RemoveFinalReset "qiskit.transpiler.passes.RemoveFinalReset") can improve quantum circuits that include resets. +> +> * The default pass managers have been improved by extending them with the newly introduced transpiler passes. In particular, the optimization level 2 preset pass manager from `generate_preset_pass_manager` and used internally by [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") has been refactored to have a better tradeoff between runtime and optimization effort in order to serve as a default pass manager in future releases. While this release doesn’t change the default to use level 2 it is typically a better choice than using level 1 or 3. +> +> * New generic primitive V2 implementations were added, [`BackendEstimatorV2`](/api/qiskit/qiskit.primitives.BackendEstimatorV2 "qiskit.primitives.BackendEstimatorV2") and [`BackendSamplerV2`](/api/qiskit/qiskit.primitives.BackendSamplerV2 "qiskit.primitives.BackendSamplerV2"), to compliment the existing full statevector based implementations. +> +> * Changes to platform support: Python 3.8 is deprecated starting with Qiskit 1.1.0 and will no longer be supported in 1.3.0, and arm64 macOS has been promoted to tier 1 support. + + + +### Circuits Features + +* The methods [`QuantumCircuit.power()`](/api/qiskit/qiskit.circuit.QuantumCircuit#power "qiskit.circuit.QuantumCircuit.power"), [`Gate.power()`](/api/qiskit/qiskit.circuit.Gate#power "qiskit.circuit.Gate.power"), as well as the similar methods on subclasses of subclasses of [`Gate`](/api/qiskit/qiskit.circuit.Gate "qiskit.circuit.Gate") (such as of [`SGate`](/api/qiskit/qiskit.circuit.library.SGate "qiskit.circuit.library.SGate")) all have an additional have a new argument `annotated` which is used to return an [`AnnotatedOperation`](/api/qiskit/qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") object when applying a power to a gate or circuit. The default value of `False` corresponds to the existing behavior. Furthermore, for standard gates with an explicitly defined `power` method, the argument `annotated` has no effect. For example, both `SGate().power(1.5, annotated=False)` and `SGate().power(1.5, annotated=True)` return a `PhaseGate`. A difference in the value of `annotated` manifests for gates without an explicitly defined power method. The value of `False` returns a [`UnitaryGate`](/api/qiskit/qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate"), just as before, while the value of `True` returns an [`AnnotatedOperation`](/api/qiskit/qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") that represents the instruction modified with the “power modifier”. + +* Added a new `ctrl_state` argument to [`QuantumCircuit.mcp()`](/api/qiskit/qiskit.circuit.QuantumCircuit#mcp "qiskit.circuit.QuantumCircuit.mcp") and [`MCPhaseGate`](/api/qiskit/qiskit.circuit.library.MCPhaseGate "qiskit.circuit.library.MCPhaseGate"). + + The [`QuantumCircuit.mcp()`](/api/qiskit/qiskit.circuit.QuantumCircuit#mcp "qiskit.circuit.QuantumCircuit.mcp") method and [`MCPhaseGate`](/api/qiskit/qiskit.circuit.library.MCPhaseGate "qiskit.circuit.library.MCPhaseGate") class have been updated to include a `ctrl_state` parameter. This enhancement allows users to specify the control state of the multi-controlled phase gate. The parameter can accept either an integer value or a bitstring and defaults to controlling the ‘1’ state if not provided. + + ```python + from qiskit import QuantumCircuit + + qc = QuantumCircuit(4) + qc.mcp(0.2,[0,1,2],3,ctrl_state=2) + ``` + +* Added a new `ctrl_state` argument to [`QuantumCircuit.mcx()`](/api/qiskit/qiskit.circuit.QuantumCircuit#mcx "qiskit.circuit.QuantumCircuit.mcx"). + + The [`QuantumCircuit.mcx()`](/api/qiskit/qiskit.circuit.QuantumCircuit#mcx "qiskit.circuit.QuantumCircuit.mcx") method in the quantum circuit library has been enhanced to include a ctrl\_state parameter, allowing users to specify the control state of the multi-controlled X gate. This parameter can accept either a decimal value or a bitstring and defaults to controlling the ‘1’ state if not provided. + + ```python + from qiskit import QuantumCircuit + + qc = QuantumCircuit(3, 3) + qc.mcx([0, 1], 2, ctrl_state="00") + ``` + +* A [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") can now contain typed classical variables: + + ```python + from qiskit.circuit import QuantumCircuit, ClassicalRegister, QuantumRegister + from qiskit.circuit.classical import expr, types + + qr = QuantumRegister(2, "q") + cr = ClassicalRegister(2, "c") + qc = QuantumCircuit(qr, cr) + # Add two input variables to the circuit with different types. + a = qc.add_input("a", types.Bool()) + mask = qc.add_input("mask", types.Uint(2)) + + # Test whether the input variable was true at runtime. + with qc.if_test(a) as else_: + qc.x(0) + with else_: + qc.h(0) + + qc.cx(0, 1) + qc.measure(qr, cr) + + # Add a typed variable manually, initialized to the same value as the classical register. + b = qc.add_var("b", expr.lift(cr)) + + qc.reset([0, 1]) + qc.h(0) + qc.cx(0, 1) + qc.measure(qr, cr) + + # Store some calculated value into the `b` variable. + qc.store(b, expr.bit_and(b, cr)) + # Test whether we had equality, up to a mask. + with qc.if_test(expr.equal(expr.bit_and(b, mask), mask)): + qc.x(0) + ``` + + These variables can be specified either as *inputs* to the circuit, or as scoped variables. The circuit object does not yet have support for representing typed classical-variable *outputs*, but this will be added later when hardware and the result interfaces are in more of a position to support it. Circuits that represent a block of an inner scope may also capture variables from outer scopes. + + A variable is a [`Var`](/api/qiskit/circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node, which can now contain an arbitrary type, and represents a unique memory location within its live range when added to a circuit. These can be constructed in a circuit using [`QuantumCircuit.add_var()`](/api/qiskit/qiskit.circuit.QuantumCircuit#add_var "qiskit.circuit.QuantumCircuit.add_var") and [`QuantumCircuit.add_input()`](/api/qiskit/qiskit.circuit.QuantumCircuit#add_input "qiskit.circuit.QuantumCircuit.add_input"), or at a lower level using `Var.new()`. + + Variables can be manually stored to, using the [`Store`](/api/qiskit/circuit#qiskit.circuit.Store "qiskit.circuit.Store") instruction and its corresponding circuit method [`QuantumCircuit.store()`](/api/qiskit/qiskit.circuit.QuantumCircuit#store "qiskit.circuit.QuantumCircuit.store"). This includes writing to [`Clbit`](/api/qiskit/circuit#qiskit.circuit.Clbit "qiskit.circuit.Clbit") and [`ClassicalRegister`](/api/qiskit/circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") instances wrapped in [`Var`](/api/qiskit/circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes. + + Variables can be used wherever classical expressions (see [`qiskit.circuit.classical.expr`](/api/qiskit/circuit_classical#module-qiskit.circuit.classical.expr "qiskit.circuit.classical.expr")) are valid. Currently this is the target expressions of control-flow operations, though we plan to expand this to gate parameters in the future, as the type and expression system are expanded. + + See [Real-time classical computation](/api/qiskit/circuit#circuit-repr-real-time-classical) for more discussion of these variables, and the associated data model. + + These are supported throughout the transpiler, through QPY serialization ([`qiskit.qpy`](/api/qiskit/qpy#module-qiskit.qpy "qiskit.qpy")), OpenQASM 3 export ([`qiskit.qasm3`](/api/qiskit/qasm3#module-qiskit.qasm3 "qiskit.qasm3")), and have initial support through the circuit visualizers (see [`QuantumCircuit.draw()`](/api/qiskit/qiskit.circuit.QuantumCircuit#draw "qiskit.circuit.QuantumCircuit.draw")). + + + The new classical variables and storage will take some time to become supported on hardware and simulator backends. They are not supported in the primitives interfaces ([`qiskit.primitives`](/api/qiskit/primitives#module-qiskit.primitives "qiskit.primitives")), but will likely inform those interfaces as they evolve. + + +* The classical realtime-expressions module [`qiskit.circuit.classical`](/api/qiskit/circuit_classical#module-qiskit.circuit.classical "qiskit.circuit.classical") can now represent indexing and bitshifting of unsigned integers and bitlikes (e.g. [`ClassicalRegister`](/api/qiskit/circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")). For example, it is now possible to compare one register with the bitshift of another: + + ```python + from qiskit.circuit import QuantumCircuit, ClassicalRegister + from qiskit.circuit.classical import expr + + cr1 = ClassicalRegister(4, "cr1") + cr2 = ClassicalRegister(4, "cr2") + qc = QuantumCircuit(cr1, cr2) + with qc.if_test(expr.equal(cr1, expr.shift_left(cr2, 2))): + pass + ``` + + Qiskit can also represent a condition that dynamically indexes into a register: + + ```python + with qc.if_test(expr.index(cr1, cr2)): + pass + ``` + +* The construction performance of [`NLocal`](/api/qiskit/qiskit.circuit.library.NLocal "qiskit.circuit.library.NLocal") and its derived circuit-library subclasses (e.g. [`EfficientSU2`](/api/qiskit/qiskit.circuit.library.EfficientSU2 "qiskit.circuit.library.EfficientSU2") and [`RealAmplitudes`](/api/qiskit/qiskit.circuit.library.RealAmplitudes "qiskit.circuit.library.RealAmplitudes")) has significantly improved, when the rotation and/or entanglement subblocks are simple applications of a single Qiskit standard-library gate. Since these circuits are constructed lazily, you might not see the improvement immediately on instantiation of the class, but instead on first access to its internal structure. Performance improvements are on the order of ten times faster. + +* [`QuantumCircuit.append()`](/api/qiskit/qiskit.circuit.QuantumCircuit#append "qiskit.circuit.QuantumCircuit.append") now has a `copy` keyword argument, which defaults to `True`. When an instruction with runtime parameters ([`ParameterExpression`](/api/qiskit/qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")s) is appended to a circuit, by default, the circuit has always created a copy of the instruction so that if [`QuantumCircuit.assign_parameters()`](/api/qiskit/qiskit.circuit.QuantumCircuit#assign_parameters "qiskit.circuit.QuantumCircuit.assign_parameters") attempts to mutate the instruction in place, it does not affect other references to the same instruction. Now, setting `copy=False` allows you to override this, so you can avoid the copy penalty if you know your instructions will not be used in other locations. + +* [`QuantumCircuit.compose()`](/api/qiskit/qiskit.circuit.QuantumCircuit#compose "qiskit.circuit.QuantumCircuit.compose") now has a `copy` keyword argument, which defaults to `True`. By default, [`compose()`](/api/qiskit/qiskit.circuit.QuantumCircuit#compose "qiskit.circuit.QuantumCircuit.compose") copies all instructions, so that mutations from one circuit do not affect any other. If `copy=False`, then instructions from the other circuit will become directly owned by the new circuit, which may involve mutating them in place. The other circuit must not be used afterwards, in this case. + +* Construction time for [`QuantumVolume`](/api/qiskit/qiskit.circuit.library.QuantumVolume "qiskit.circuit.library.QuantumVolume") circuits has been significantly improved, on the order of 10x or a bit more. The internal SU4 gates will now also use more bits of randomness during their generation, leading to more representative volume circuits, especially at large widths and depths. + +* [`QuantumVolume`](/api/qiskit/qiskit.circuit.library.QuantumVolume "qiskit.circuit.library.QuantumVolume") now has a `flatten` keyword argument. This defaults to `False`, where the constructed circuit contains a single instruction that in turn contains the actual volume structure. If set `True`, the circuit will directly have the volumetric SU4 matrices. + +* [`UnitaryGate`](/api/qiskit/qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate") now accepts an optional `num_qubits` argument. The only effect of this is to skip the inference of the qubit count, which can be helpful for performance when many gates are being constructed. + +* [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") has several new methods to work with and inspect manual [`Var`](/api/qiskit/circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") variables. + + See [Working with real-time typed classical data](/api/qiskit/qiskit.circuit.QuantumCircuit#circuit-real-time-methods) for more in-depth discussion on all of these. + + The new methods are: + + * [`add_var()`](/api/qiskit/qiskit.circuit.QuantumCircuit#add_var "qiskit.circuit.QuantumCircuit.add_var") + * [`add_input()`](/api/qiskit/qiskit.circuit.QuantumCircuit#add_input "qiskit.circuit.QuantumCircuit.add_input") + * [`add_capture()`](/api/qiskit/qiskit.circuit.QuantumCircuit#add_capture "qiskit.circuit.QuantumCircuit.add_capture") + * [`add_uninitialized_var()`](/api/qiskit/qiskit.circuit.QuantumCircuit#add_uninitialized_var "qiskit.circuit.QuantumCircuit.add_uninitialized_var") + * [`get_var()`](/api/qiskit/qiskit.circuit.QuantumCircuit#get_var "qiskit.circuit.QuantumCircuit.get_var") + * [`has_var()`](/api/qiskit/qiskit.circuit.QuantumCircuit#has_var "qiskit.circuit.QuantumCircuit.has_var") + * [`iter_vars()`](/api/qiskit/qiskit.circuit.QuantumCircuit#iter_vars "qiskit.circuit.QuantumCircuit.iter_vars") + * [`iter_declared_vars()`](/api/qiskit/qiskit.circuit.QuantumCircuit#iter_declared_vars "qiskit.circuit.QuantumCircuit.iter_declared_vars") + * [`iter_captured_vars()`](/api/qiskit/qiskit.circuit.QuantumCircuit#iter_captured_vars "qiskit.circuit.QuantumCircuit.iter_captured_vars") + * [`iter_input_vars()`](/api/qiskit/qiskit.circuit.QuantumCircuit#iter_input_vars "qiskit.circuit.QuantumCircuit.iter_input_vars") + * [`store()`](/api/qiskit/qiskit.circuit.QuantumCircuit#store "qiskit.circuit.QuantumCircuit.store") + + In addition, there are several new dynamic attributes on [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") surrounding these variables: + + * [`num_vars`](/api/qiskit/qiskit.circuit.QuantumCircuit#num_vars "qiskit.circuit.QuantumCircuit.num_vars") + * [`num_input_vars`](/api/qiskit/qiskit.circuit.QuantumCircuit#num_input_vars "qiskit.circuit.QuantumCircuit.num_input_vars") + * [`num_captured_vars`](/api/qiskit/qiskit.circuit.QuantumCircuit#num_captured_vars "qiskit.circuit.QuantumCircuit.num_captured_vars") + * [`num_declared_vars`](/api/qiskit/qiskit.circuit.QuantumCircuit#num_declared_vars "qiskit.circuit.QuantumCircuit.num_declared_vars") + +* [`ControlFlowOp`](/api/qiskit/qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") and its subclasses now have a [`iter_captured_vars()`](/api/qiskit/qiskit.circuit.ControlFlowOp#iter_captured_vars "qiskit.circuit.ControlFlowOp.iter_captured_vars") method, which will return an iterator over the unique variables captured in any of its immediate blocks. + +* [`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") has several new methods to work with and inspect manual [`Var`](/api/qiskit/circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") variables. These are largely equivalent to their [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") counterparts, except that the [`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") ones are optimized for programmatic access with already defined objects, while the [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") methods are more focussed on interactive human use. + + The new methods are: + + * [`add_input_var()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#add_input_var "qiskit.dagcircuit.DAGCircuit.add_input_var") + * [`add_captured_var()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#add_captured_var "qiskit.dagcircuit.DAGCircuit.add_captured_var") + * [`add_declared_var()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#add_declared_var "qiskit.dagcircuit.DAGCircuit.add_declared_var") + * [`has_var()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#has_var "qiskit.dagcircuit.DAGCircuit.has_var") + * [`iter_vars()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#iter_vars "qiskit.dagcircuit.DAGCircuit.iter_vars") + * [`iter_declared_vars()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#iter_declared_vars "qiskit.dagcircuit.DAGCircuit.iter_declared_vars") + * [`iter_captured_vars()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#iter_captured_vars "qiskit.dagcircuit.DAGCircuit.iter_captured_vars") + * [`iter_input_vars()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#iter_input_vars "qiskit.dagcircuit.DAGCircuit.iter_input_vars") + + There are also new public attributes: + + * [`num_vars`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#num_vars "qiskit.dagcircuit.DAGCircuit.num_vars") + * [`num_input_vars`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#num_input_vars "qiskit.dagcircuit.DAGCircuit.num_input_vars") + * [`num_captured_vars`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#num_captured_vars "qiskit.dagcircuit.DAGCircuit.num_captured_vars") + * [`num_declared_vars`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#num_declared_vars "qiskit.dagcircuit.DAGCircuit.num_declared_vars") + +* [`DAGCircuit.wires`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#wires "qiskit.dagcircuit.DAGCircuit.wires") will now also contain any [`Var`](/api/qiskit/circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") manual variables in the circuit as well, as these are also classical data flow. + +* A new method, [`Var.new()`](/api/qiskit/circuit_classical#qiskit.circuit.classical.expr.Var.new "qiskit.circuit.classical.expr.Var.new"), is added to manually construct a real-time classical variable that owns its memory. + +* [`QuantumCircuit.compose()`](/api/qiskit/qiskit.circuit.QuantumCircuit#compose "qiskit.circuit.QuantumCircuit.compose") has two need keyword arguments, `var_remap` and `inline_captures` to better support real-time classical variables. + + `var_remap` can be used to rewrite [`Var`](/api/qiskit/circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes in the circuit argument as its instructions are inlined onto the base circuit. This can be used to avoid naming conflicts. + + `inline_captures` can be set to `True` (defaults to `False`) to link all [`Var`](/api/qiskit/circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes tracked as “captures” in the argument circuit with the same [`Var`](/api/qiskit/circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes in the base circuit, without attempting to redeclare the variables. This can be used, in combination with [`QuantumCircuit.copy_empty_like()`](/api/qiskit/qiskit.circuit.QuantumCircuit#copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like")’s `vars_mode="captures"` handling, to build up a circuit layer by layer, containing variables. + +* [`DAGCircuit.compose()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#compose "qiskit.dagcircuit.DAGCircuit.compose") has a new keyword argument, `inline_captures`, which can be set to `True` to inline “captured” [`Var`](/api/qiskit/circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes on the argument circuit onto the base circuit without redeclaring them. In conjunction with the `vars_mode="captures"` option to several [`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") methods, this can be used to combine DAGs that operate on the same variables. + +* [`QuantumCircuit.copy_empty_like()`](/api/qiskit/qiskit.circuit.QuantumCircuit#copy_empty_like "qiskit.circuit.QuantumCircuit.copy_empty_like") and [`DAGCircuit.copy_empty_like()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#copy_empty_like "qiskit.dagcircuit.DAGCircuit.copy_empty_like") have a new keyword argument, `vars_mode` which controls how any memory-owning [`Var`](/api/qiskit/circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes are tracked in the output. By default (`"alike"`), the variables are declared in the same input/captured/local mode as the source. This can be set to `"captures"` to convert all variables to captures (useful with [`compose()`](/api/qiskit/qiskit.circuit.QuantumCircuit#compose "qiskit.circuit.QuantumCircuit.compose")) or `"drop"` to remove them. + +* A new `vars_mode` keyword argument has been added to the [`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") methods: + + * [`separable_circuits()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#separable_circuits "qiskit.dagcircuit.DAGCircuit.separable_circuits") + * [`layers()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#layers "qiskit.dagcircuit.DAGCircuit.layers") + * [`serial_layers()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#serial_layers "qiskit.dagcircuit.DAGCircuit.serial_layers") + + which has the same meaning as it does for [`copy_empty_like()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#copy_empty_like "qiskit.dagcircuit.DAGCircuit.copy_empty_like"). + +* All of the “standard gates” in the circuit library ([`qiskit.circuit.library`](/api/qiskit/circuit_library#module-qiskit.circuit.library "qiskit.circuit.library")) can now be specified by string name for the entangling operations in [`TwoLocal`](/api/qiskit/qiskit.circuit.library.TwoLocal "qiskit.circuit.library.TwoLocal") circuits, such as [`RealAmplitudes`](/api/qiskit/qiskit.circuit.library.RealAmplitudes "qiskit.circuit.library.RealAmplitudes") and [`EfficientSU2`](/api/qiskit/qiskit.circuit.library.EfficientSU2 "qiskit.circuit.library.EfficientSU2"). + + + +### Primitives Features + +* The implementation [`BackendEstimatorV2`](/api/qiskit/qiskit.primitives.BackendEstimatorV2 "qiskit.primitives.BackendEstimatorV2") of [`BaseEstimatorV2`](/api/qiskit/qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") was added. This estimator supports [`BackendV1`](/api/qiskit/qiskit.providers.BackendV1 "qiskit.providers.BackendV1") and [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "qiskit.providers.BackendV2"). + + ```python + import numpy as np + from qiskit import transpile + from qiskit.circuit.library import IQP + from qiskit.primitives import BackendEstimatorV2 + from qiskit.providers.fake_provider import Fake7QPulseV1 + from qiskit.quantum_info import SparsePauliOp, random_hermitian + + backend = Fake7QPulseV1() + estimator = BackendEstimatorV2(backend=backend) + n_qubits = 5 + mat = np.real(random_hermitian(n_qubits, seed=1234)) + circuit = IQP(mat) + observable = SparsePauliOp("Z" * n_qubits) + isa_circuit = transpile(circuit, backend=backend, optimization_level=1) + isa_observable = observable.apply_layout(isa_circuit.layout) + job = estimator.run([(isa_circuit, isa_observable)], precision=0.01) + result = job.result() + print(f"> Expectation value: {result[0].data.evs}") + print(f"> Standard error: {result[0].data.stds}") + print(f"> Metadata: {result[0].metadata}") + ``` + +* The implementation [`BackendSamplerV2`](/api/qiskit/qiskit.primitives.BackendSamplerV2 "qiskit.primitives.BackendSamplerV2") of [`BaseSamplerV2`](/api/qiskit/qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") was added. This sampler supports [`BackendV1`](/api/qiskit/qiskit.providers.BackendV1 "qiskit.providers.BackendV1") and [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "qiskit.providers.BackendV2") that allow `memory` option to compute bitstrings. + + ```python + import numpy as np + from qiskit import transpile + from qiskit.circuit.library import IQP + from qiskit.primitives import BackendSamplerV2 + from qiskit.providers.fake_provider import Fake7QPulseV1 + from qiskit.quantum_info import random_hermitian + + backend = Fake7QPulseV1() + sampler = BackendSamplerV2(backend=backend) + n_qubits = 5 + mat = np.real(random_hermitian(n_qubits, seed=1234)) + circuit = IQP(mat) + circuit.measure_all() + isa_circuit = transpile(circuit, backend=backend, optimization_level=1) + job = sampler.run([isa_circuit], shots=100) + result = job.result() + print(f"> bitstrings: {result[0].data.meas.get_bitstrings()}") + print(f"> counts: {result[0].data.meas.get_counts()}") + print(f"> Metadata: {result[0].metadata}") + ``` + +* Added methods to join multiple [`BitArray`](/api/qiskit/qiskit.primitives.BitArray "qiskit.primitives.BitArray") objects along various axes. + + * [`concatenate()`](/api/qiskit/qiskit.primitives.BitArray#concatenate "qiskit.primitives.BitArray.concatenate"): join arrays along an existing axis of the arrays. + * [`concatenate_bits()`](/api/qiskit/qiskit.primitives.BitArray#concatenate_bits "qiskit.primitives.BitArray.concatenate_bits"): join arrays along the bit axis. + * [`concatenate_shots()`](/api/qiskit/qiskit.primitives.BitArray#concatenate_shots "qiskit.primitives.BitArray.concatenate_shots"): join arrays along the shots axis. + + ```python + ba = BitArray.from_samples(['00', '11']) + print(ba) + # BitArray() + + # reshape the bit array because `concatenate` requires an axis. + ba_ = ba.reshape(1, 2) + print(ba_) + # BitArray() + + ba2 = BitArray.concatenate([ba_, ba_]) + print(ba2.get_bitstrings()) + # ['00', '11', '00', '11'] + + # `concatenate_bits` and `concatenates_shots` do not require any axis. + + ba3 = BitArray.concatenate_bits([ba, ba]) + print(ba3.get_bitstrings()) + # ['0000', '1111'] + + ba4 = BitArray.concatenate_shots([ba, ba]) + print(ba4.get_bitstrings()) + # ['00', '11', '00', '11'] + ``` + +* Added methods to generate a subset of [`BitArray`](/api/qiskit/qiskit.primitives.BitArray "qiskit.primitives.BitArray") object by slicing along various axes. + + * `__getitem__()`: slice the array along an existing axis of the array. + * [`slice_bits()`](/api/qiskit/qiskit.primitives.BitArray#slice_bits "qiskit.primitives.BitArray.slice_bits"): slice the array along the bit axis. + * [`slice_shots()`](/api/qiskit/qiskit.primitives.BitArray#slice_shots "qiskit.primitives.BitArray.slice_shots"): slice the array along the shot axis. + + ```python + ba = BitArray.from_samples(['0000', '0001', '0010', '0011'], 4) + print(ba) + # BitArray() + print(ba.get_bitstrings()) + # ['0000', '0001', '0010', '0011'] + + ba2 = ba.reshape(2, 2) + print(ba2) + # BitArray() + print(ba2[0].get_bitstrings()) + # ['0000', '0001'] + print(ba2[1].get_bitstrings()) + # ['0010', '0011'] + + ba3 = ba.slice_bits([0, 2]) + print(ba3.get_bitstrings()) + # ['00', '01', '00', '01'] + + ba4 = ba.slice_shots([0, 2]) + print(ba3.get_bitstrings()) + # ['0000', '0010'] + ``` + +* Added a method [`transpose()`](/api/qiskit/qiskit.primitives.BitArray#transpose "qiskit.primitives.BitArray.transpose") to transpose a [`BitArray`](/api/qiskit/qiskit.primitives.BitArray "qiskit.primitives.BitArray"). + + ```python + ba = BitArray.from_samples(['00', '11']).reshape(2, 1, 1) + print(ba) + # BitArray() + print(ba.transpose()) + # BitArray() + ``` + +* Added a method [`expectation_values()`](/api/qiskit/qiskit.primitives.BitArray#expectation_values "qiskit.primitives.BitArray.expectation_values") to compute expectation values of diagonal operators. + + ```python + ba = BitArray.from_samples(['01', '11']) + print(ba.expectation_values(["IZ", "ZI", "01"])) + # [-1. 0. 0.5] + ``` + +* [`DataBin`](/api/qiskit/qiskit.primitives.DataBin "qiskit.primitives.DataBin") now satisfies the [`Shaped`](/api/qiskit/qiskit.primitives.Shaped "qiskit.primitives.Shaped") protocol. This means that every [`DataBin`](/api/qiskit/qiskit.primitives.DataBin "qiskit.primitives.DataBin") instance now has the additional attributes + + * [`shape`](/api/qiskit/qiskit.primitives.DataBin#shape "qiskit.primitives.DataBin.shape") (tuple\[int, …]): the leading shape of every entry in the instance + * [`ndim`](/api/qiskit/qiskit.primitives.DataBin#ndim "qiskit.primitives.DataBin.ndim") (int): the length of [`shape`](/api/qiskit/qiskit.primitives.DataBin#shape "qiskit.primitives.DataBin.shape") + * [`size`](/api/qiskit/qiskit.primitives.DataBin#size "qiskit.primitives.DataBin.size") (int): the product of the entries of [`shape`](/api/qiskit/qiskit.primitives.DataBin#shape "qiskit.primitives.DataBin.shape") + + The shape can be passed to the constructor. + +* Added mapping-like features to [`DataBin`](/api/qiskit/qiskit.primitives.DataBin "qiskit.primitives.DataBin"), i.e., `__getitem__`, `__contains__`, `__iter__`, [`keys()`](/api/qiskit/qiskit.primitives.DataBin#keys "qiskit.primitives.DataBin.keys"), [`values()`](/api/qiskit/qiskit.primitives.DataBin#values "qiskit.primitives.DataBin.values"), and [`items()`](/api/qiskit/qiskit.primitives.DataBin#items "qiskit.primitives.DataBin.items"). + + ```python + from qiskit import QuantumCircuit + from qiskit.primitives import StatevectorSampler + + circuit = QuantumCircuit(1) + circuit.h(0) + circuit.measure_all() + + sampler = StatevectorSampler() + result = sampler.run([circuit]).result() + databin = result[0].data + for creg, arr in databin.items(): + print(creg, arr) + for creg in databin: + print(creg, databin[creg]) + ``` + +* The subclass [`SamplerPubResult`](/api/qiskit/qiskit.primitives.SamplerPubResult "qiskit.primitives.SamplerPubResult") of [`PubResult`](/api/qiskit/qiskit.primitives.PubResult "qiskit.primitives.PubResult") was added, which [`BaseSamplerV2`](/api/qiskit/qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") implementations can return. The main feature added in this new subclass is [`join_data()`](/api/qiskit/qiskit.primitives.SamplerPubResult#join_data "qiskit.primitives.SamplerPubResult.join_data"), which joins together (a subset of) the contents of [`data`](/api/qiskit/qiskit.primitives.PubResult#data "qiskit.primitives.PubResult.data") into a single object. This enables the following patterns: + + ```python + job_result = sampler.run([pub1, pub2, pub3], shots=123).result() + + # assuming all returned data entries are BitArrays + counts1 = job_result[0].join_data().get_counts() + bistrings2 = job_result[1].join_data().get_bitstrings() + array3 = job_result[2].join_data().array + ``` + + + +### Providers Features + +* The [`BasicSimulator`](/api/qiskit/qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") python-based simulator included in [`basic_provider`](/api/qiskit/providers_basic_provider#module-qiskit.providers.basic_provider "qiskit.providers.basic_provider") now supports running all the standard gates up to 3 qubits defined in [`qiskit.circuit.library`](/api/qiskit/circuit_library#module-qiskit.circuit.library "qiskit.circuit.library"). + + + +### Pulse Features + +* It is now possible to assign parameters to pulse [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "qiskit.pulse.Schedule") and [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") objects by specifying the parameter name as a string. The parameter name can be used to assign values to all parameters within the [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "qiskit.pulse.Schedule") or [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") that have the same name. Moreover, the parameter name of a [`ParameterVector`](/api/qiskit/qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used to assign all values of the vector simultaneously (the list of values should therefore match the length of the vector). + +* The `assign_parameters` methods of [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "qiskit.pulse.Schedule") and [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") now support assigning a [`ParameterVector`](/api/qiskit/qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") to a list of parameter values simultaneously in addition to assigning individual [`Parameter`](/api/qiskit/qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances to individual values. + + + +### OpenQASM Features + +* The OpenQASM 3 exporter supports manual-storage [`Var`](/api/qiskit/circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes on circuits. + + + +### QPY Features + +* QPY ([`qiskit.qpy`](/api/qiskit/qpy#module-qiskit.qpy "qiskit.qpy")) format version 12 has been added, which includes support for memory-owning [`Var`](/api/qiskit/circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") variables. See [Version 12](/api/qiskit/qpy#qpy-version-12) for more detail on the format changes. + + + +### Quantum Information Features + +* Added a new [`Pauli.apply_layout()`](/api/qiskit/qiskit.quantum_info.Pauli#apply_layout "qiskit.quantum_info.Pauli.apply_layout") that is equivalent to the [`SparsePauliOp.apply_layout()`](/api/qiskit/qiskit.quantum_info.SparsePauliOp#apply_layout "qiskit.quantum_info.SparsePauliOp.apply_layout"). This method is used to apply a [`TranspileLayout`](/api/qiskit/qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") layout from the transpiler to a [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") observable that was built for an input circuit. This enables working with `BaseEstimator` / [`BaseEstimatorV2`](/api/qiskit/qiskit.primitives.BaseEstimatorV2 "qiskit.primitives.BaseEstimatorV2") implementations and local transpilation when the input is of type [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli"). For example: + + ```python + from qiskit.circuit.library import RealAmplitudes + from qiskit.primitives import BackendEstimatorV2 + from qiskit.providers.fake_provider import GenericBackendV2 + from qiskit.quantum_info import Pauli + from qiskit.transpiler.preset_passmanagers import generate_preset_pass_manager + + psi = RealAmplitudes(num_qubits=2, reps=2) + H1 = Pauli("XI") + backend = GenericBackendV2(num_qubits=7) + estimator = BackendEstimatorV2(backend=backend) + thetas = [0, 1, 1, 2, 3, 5] + pm = generate_preset_pass_manager(optimization_level=3, backend=backend) + transpiled_psi = pm.run(psi) + permuted_op = H1.apply_layout(transpiled_psi.layout) + res = estimator.run([(transpiled_psi, permuted_op, thetas)]).result() + ``` + + where an input circuit is transpiled locally before it’s passed to `run()`. Transpilation expands the original circuit from 2 to 7 qubits (the size of `backend`) and permutes its layout, which is then applied to `H1` using [`apply_layout()`](/api/qiskit/qiskit.quantum_info.Pauli#apply_layout "qiskit.quantum_info.Pauli.apply_layout") to reflect the transformations performed by `pm.run()`. + +* Adds the [`PauliList.noncommutation_graph()`](/api/qiskit/qiskit.quantum_info.PauliList#noncommutation_graph "qiskit.quantum_info.PauliList.noncommutation_graph") and [`SparsePauliOp.noncommutation_graph()`](/api/qiskit/qiskit.quantum_info.SparsePauliOp#noncommutation_graph "qiskit.quantum_info.SparsePauliOp.noncommutation_graph") methods, exposing the construction of non-commutation graphs, recasting the measurement operator grouping problem into a graph coloring problem. This permits users to work with these graphs directly, for example to explore coloring algorithms other than the one used by [`SparsePauliOp.group_commuting()`](/api/qiskit/qiskit.quantum_info.SparsePauliOp#group_commuting "qiskit.quantum_info.SparsePauliOp.group_commuting"). + +* The performance of [`SparsePauliOp.to_matrix()`](/api/qiskit/qiskit.quantum_info.SparsePauliOp#to_matrix "qiskit.quantum_info.SparsePauliOp.to_matrix") has been greatly improved for both dense and sparse forms. By default, both will now take advantage of threaded parallelism available on your system, subject to the `RAYON_NUM_THREADS` environment variable. You can temporarily force serial execution using the new `force_serial` Boolean argument to [`to_matrix()`](/api/qiskit/qiskit.quantum_info.SparsePauliOp#to_matrix "qiskit.quantum_info.SparsePauliOp.to_matrix"). + + + +### Synthesis Features + +* The [`KMSSynthesisLinearFunction`](/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction "qiskit.transpiler.passes.synthesis.high_level_synthesis.KMSSynthesisLinearFunction") plugin for synthesizing [`LinearFunction`](/api/qiskit/qiskit.circuit.library.LinearFunction "qiskit.circuit.library.LinearFunction") objects now accepts two additional options `use_inverted` and `use_transposed`. These option modify the matrix on which the underlying synthesis algorithm runs by possibly inverting and/or transposing it, and then suitably adjust the synthesized circuit. By varying these options, we generally get different synthesized circuits, and in cases may obtain better results than for their default values. + +* The [`PMHSynthesisLinearFunction`](/api/qiskit/qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction "qiskit.transpiler.passes.synthesis.high_level_synthesis.PMHSynthesisLinearFunction") plugin for synthesizing [`LinearFunction`](/api/qiskit/qiskit.circuit.library.LinearFunction "qiskit.circuit.library.LinearFunction") objects now accepts several additional options. The option `section_size` is passed to the underlying synthesis method. The options `use_inverted` and `use_transposed` modify the matrix on which the underlying synthesis algorithm runs by possibly inverting and/or transposing it, and then suitably adjust the synthesized circuit. By varying these options, we generally get different synthesized circuits, and in cases may obtain better results than for their default values. + +* Added a new argument, `use_dag`, to the [`TwoQubitBasisDecomposer.__call__()`](/api/qiskit/qiskit.synthesis.TwoQubitBasisDecomposer#__call__ "qiskit.synthesis.TwoQubitBasisDecomposer.__call__") and [`XXDecomposer.__call__()`](/api/qiskit/qiskit.synthesis.XXDecomposer#__call__ "qiskit.synthesis.XXDecomposer.__call__") methods. This argument is used to control whether a [`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") is returned when calling a [`TwoQubitBasisDecomposer`](/api/qiskit/qiskit.synthesis.TwoQubitBasisDecomposer "qiskit.synthesis.TwoQubitBasisDecomposer") or [`XXDecomposer`](/api/qiskit/qiskit.synthesis.XXDecomposer "qiskit.synthesis.XXDecomposer") instance instead of the default [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). For example: + + ```python + from qiskit.circuit.library import CXGate + from qiskit.quantum_info import random_unitary + from qiskit.synthesis import TwoQubitBasisDecomposer + + decomposer = TwoQubitBasisDecomposer(CXGate(), euler_basis="PSX") + decomposer(random_unitary(4), use_dag=True) + ``` + + will return a [`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") when calling the [`TwoQubitBasisDecomposer`](/api/qiskit/qiskit.synthesis.TwoQubitBasisDecomposer "qiskit.synthesis.TwoQubitBasisDecomposer") instance `decomposer`. + +* [`LieTrotter.synthesize()`](/api/qiskit/qiskit.synthesis.LieTrotter#synthesize "qiskit.synthesis.LieTrotter.synthesize") now uses [`QuantumCircuit.repeat()`](/api/qiskit/qiskit.circuit.QuantumCircuit#repeat "qiskit.circuit.QuantumCircuit.repeat") to generate additional repetitions of a Trotter step after the first Trotter step. This reduces the number of [`QuantumCircuit.compose()`](/api/qiskit/qiskit.circuit.QuantumCircuit#compose "qiskit.circuit.QuantumCircuit.compose") calls by a factor of `reps` and significantly reduces the runtime for larger operators. + +* Add a new synthesis method [`synth_permutation_reverse_lnn_kms()`](/api/qiskit/synthesis#qiskit.synthesis.synth_permutation_reverse_lnn_kms "qiskit.synthesis.synth_permutation_reverse_lnn_kms") of reverse permutations for linear nearest-neighbor architectures using Kutin, Moulton, Smithline method. This algorithm synthesizes the reverse permutation on $n$ qubits over a linear nearest-neighbor architecture using CX gates with depth $2 * n + 2$. + +* The [`TwoQubitBasisDecomposer`](/api/qiskit/qiskit.synthesis.TwoQubitBasisDecomposer "qiskit.synthesis.TwoQubitBasisDecomposer") class has been rewritten in Rust which greatly improves the runtime performance. + +* The [`TwoQubitWeylDecomposition`](/api/qiskit/qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.TwoQubitWeylDecomposition") synthesis class has been rewritten in Rust for better performance. + + + +### Transpiler Features + +* Extended the commutation analysis performed by `CommutationChecker` to also work with abstract circuits, i.e. each operation in the input quantum circuit is now checked for its matrix representation before proceeding to the analysis step. Previously, the commutation analysis was only performed on physical circuits. In addition, each operation is now checked for its ability to be cached in the session commutation library. For example, this now enables computing whether [`AnnotatedOperation`](/api/qiskit/qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") commute. This enables transpiler passes that rely on `CommutationChecker` internally, such as [`CommutativeCancellation`](/api/qiskit/qiskit.transpiler.passes.CommutativeCancellation "qiskit.transpiler.passes.CommutativeCancellation"), to run during earlier stages of a default transpilation pipeline (prior to basis translation). + +* The transpiler pass [`ElidePermutations`](/api/qiskit/qiskit.transpiler.passes.ElidePermutations "qiskit.transpiler.passes.ElidePermutations") runs by default in the init stage for optimization levels 2 and 3. Intuitively, removing [`SwapGate`](/api/qiskit/qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s and [`PermutationGate`](/api/qiskit/qiskit.circuit.library.PermutationGate "qiskit.circuit.library.PermutationGate")s in a virtual circuit is almost always beneficial, as it makes the circuit shorter and easier to route. As `OptimizeSwapBeforeMeasure` is a special case of [`ElidePermutations`](/api/qiskit/qiskit.transpiler.passes.ElidePermutations "qiskit.transpiler.passes.ElidePermutations"), it has been replaced by the `ElidePermuations` pass as part of the init stage in optimization level 3 pass managers. + +* Added a new optimization transpiler pass, [`ElidePermutations`](/api/qiskit/qiskit.transpiler.passes.ElidePermutations "qiskit.transpiler.passes.ElidePermutations"), which is designed to run prior to the [Layout Stage](/api/qiskit/transpiler#layout-stage) and will optimize away any [`SwapGate`](/api/qiskit/qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s and [`PermutationGate`](/api/qiskit/qiskit.circuit.library.PermutationGate "qiskit.circuit.library.PermutationGate")s in a circuit by permuting virtual qubits. For example, taking a circuit with [`SwapGate`](/api/qiskit/qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s: + + ![\_images/release\_notes-1.png](/images/api/qiskit/release_notes-1.png) + + will remove the swaps when the pass is run: + + ```python + from qiskit.transpiler.passes import ElidePermutations + from qiskit.circuit import QuantumCircuit + + qc = QuantumCircuit(3) + qc.h(0) + qc.swap(0, 1) + qc.swap(2, 0) + qc.cx(1, 0) + qc.measure_all() + + ElidePermutations()(qc).draw("mpl") + ``` + + ![\_images/release\_notes-2.png](/images/api/qiskit/release_notes-2.png) + + The pass also sets the `virtual_permutation_layout` property set, storing the permutation of the virtual qubits at the end of the circuit that was optimized away. + +* The [`HLSConfig`](/api/qiskit/qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.HLSConfig") now has two additional optional arguments. The argument `plugin_selection` can be set either to `"sequential"` or to `"all"`. If set to “sequential” (default), for every higher-level-object the [`HighLevelSynthesis`](/api/qiskit/qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis") pass will consider the specified methods sequentially, in the order they appear in the list, stopping at the first method that is able to synthesize the object. If set to “all”, all the specified methods will be considered, and the best synthesized circuit, according to `plugin_evaluation_fn` will be chosen. The argument `plugin_evaluation_fn` is an optional callable that evaluates the quality of the synthesized quantum circuit; a smaller value means a better circuit. When set to `None`, the quality of the circuit is its size (i.e. the number of gates that it contains). + + The following example illustrates the new functionality: + + ```python + from qiskit import QuantumCircuit + from qiskit.circuit.library import LinearFunction + from qiskit.synthesis.linear import random_invertible_binary_matrix + from qiskit.transpiler.passes import HighLevelSynthesis, HLSConfig + + # Create a circuit with a linear function + mat = random_invertible_binary_matrix(7, seed=37) + qc = QuantumCircuit(7) + qc.append(LinearFunction(mat), [0, 1, 2, 3, 4, 5, 6]) + + # Run different methods with different parameters, + # choosing the best result in terms of depth. + hls_config = HLSConfig( + linear_function=[ + ("pmh", {}), + ("pmh", {"use_inverted": True}), + ("pmh", {"use_transposed": True}), + ("pmh", {"use_inverted": True, "use_transposed": True}), + ("pmh", {"section_size": 1}), + ("pmh", {"section_size": 3}), + ("kms", {}), + ("kms", {"use_inverted": True}), + ], + plugin_selection="all", + plugin_evaluation_fn=lambda circuit: circuit.depth(), + ) + + # synthesize + qct = HighLevelSynthesis(hls_config=hls_config)(qc) + ``` + + In the example, we run multiple synthesis methods with different parameters, choosing the best circuit in terms of depth. Note that optimizing `circuit.size()` instead would pick a different circuit. + +* Added the [`CommutativeCancellation`](/api/qiskit/qiskit.transpiler.passes.CommutativeCancellation "qiskit.transpiler.passes.CommutativeCancellation") pass to the `init` stage of the preset pass managers for optimization levels 2 and 3. This enables the preset pass managers to cancel additional logical operations at the beginning of the compilation pipeline. + +* The following analysis passes now accept constraints encoded in a [`Target`](/api/qiskit/qiskit.transpiler.Target "qiskit.transpiler.Target") thanks to a new `target` input argument: + + > * [`InstructionDurationCheck`](/api/qiskit/qiskit.transpiler.passes.InstructionDurationCheck "qiskit.transpiler.passes.InstructionDurationCheck") + > * [`ConstrainedReschedule`](/api/qiskit/qiskit.transpiler.passes.ConstrainedReschedule "qiskit.transpiler.passes.ConstrainedReschedule") + > * [`ValidatePulseGates`](/api/qiskit/qiskit.transpiler.passes.ValidatePulseGates "qiskit.transpiler.passes.ValidatePulseGates") + + The target constraints will have priority over user-provided constraints, for coherence with the rest of the transpiler pipeline. + +* Added a new method [`Layout.inverse()`](/api/qiskit/qiskit.transpiler.Layout#inverse "qiskit.transpiler.Layout.inverse") which is used for taking the inverse of a [`Layout`](/api/qiskit/qiskit.transpiler.Layout "qiskit.transpiler.Layout") object. Added a new method [`Layout.compose()`](/api/qiskit/qiskit.transpiler.Layout#compose "qiskit.transpiler.Layout.compose") which is used for composing two [`Layout`](/api/qiskit/qiskit.transpiler.Layout "qiskit.transpiler.Layout") objects together. Added a new method [`Layout.to_permutation()`](/api/qiskit/qiskit.transpiler.Layout#to_permutation "qiskit.transpiler.Layout.to_permutation") which is used for creating a permutation corresponding to a [`Layout`](/api/qiskit/qiskit.transpiler.Layout "qiskit.transpiler.Layout") object. + +* Added a new reduction to the [`OptimizeAnnotated`](/api/qiskit/qiskit.transpiler.passes.OptimizeAnnotated "qiskit.transpiler.passes.OptimizeAnnotated") transpiler pass. This reduction looks for annotated operations (objects of type [`AnnotatedOperation`](/api/qiskit/qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation") that consist of a base operation $B$ and a list $M$ of control, inverse and power modifiers) with the following properties: + + * the base operation $B$ needs to be synthesized (i.e. it’s not already supported by the target or belongs to the equivalence library) + * the definition circuit for $B$ can be expressed as $P$ – $Q$ – $R$ with $R = P^{-1}$ + + In this case the modifiers can be moved to the $Q$-part only. As a specific example, controlled QFT-based adders have the form `control - [QFT -- U -- IQFT]`, which can be simplified to `QFT -- control-[U] -- IQFT`. By removing the controls over `QFT` and `IQFT` parts of the circuit, one obtains significantly fewer gates in the transpiled circuit. + +* Added two new methods to the [`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") class: [`qiskit.dagcircuit.DAGCircuit.op_successors()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#op_successors "qiskit.dagcircuit.DAGCircuit.op_successors") returns an iterator to [`DAGOpNode`](/api/qiskit/qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode") successors of a node, and [`qiskit.dagcircuit.DAGCircuit.op_successors()`](/api/qiskit/qiskit.dagcircuit.DAGCircuit#op_successors "qiskit.dagcircuit.DAGCircuit.op_successors") returns an iterator to [`DAGOpNode`](/api/qiskit/qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode") predecessors of a node. + +* Added a new transpiler pass, [`RemoveFinalReset`](/api/qiskit/qiskit.transpiler.passes.RemoveFinalReset "qiskit.transpiler.passes.RemoveFinalReset"), which will remove any [`Reset`](/api/qiskit/circuit#qiskit.circuit.Reset "qiskit.circuit.Reset") operation which is the final instruction on a qubit wire. For example, taking a circuit with final [`Reset`](/api/qiskit/circuit#qiskit.circuit.Reset "qiskit.circuit.Reset")s: + + ![\_images/release\_notes-3.png](/images/api/qiskit/release_notes-3.png) + + will remove the final resets when the pass is run: + + ```python + from qiskit.transpiler.passes import RemoveFinalReset + from qiskit.circuit import QuantumCircuit + + qc = QuantumCircuit(3, 1) + qc.reset(0) + qc.h(range(3)) + qc.cx(1, 0) + qc.measure(0, 0) + qc.reset(range(3)) + RemoveFinalReset()(qc).draw("mpl") + ``` + + ![\_images/release\_notes-4.png](/images/api/qiskit/release_notes-4.png) + +* Added a new transpiler pass [`StarPreRouting`](/api/qiskit/qiskit.transpiler.passes.StarPreRouting "qiskit.transpiler.passes.StarPreRouting") which is designed to identify star connectivity subcircuits and then replace them with an optimal linear routing. This is useful for certain circuits that are composed of this circuit connectivity such as Bernstein-Vazirani and QFT. For example: + + ![\_images/release\_notes-5.png](/images/api/qiskit/release_notes-5.png) + + ```python + from qiskit.circuit import QuantumCircuit + from qiskit.transpiler.passes import StarPreRouting + + qc = QuantumCircuit(5) + qc.h(0) + qc.cx(0, range(1, 5)) + StarPreRouting()(qc).draw("mpl") + ``` + + ![\_images/release\_notes-6.png](/images/api/qiskit/release_notes-6.png) + + Alternatively, an existing preset pass manager can be extended by: + + ```python + from qiskit import QuantumCircuit + from qiskit.transpiler import CouplingMap + from qiskit.transpiler.passes import StarPreRouting + from qiskit.transpiler.preset_passmanagers import generate_preset_pass_manager + + cm = CouplingMap.from_line(5) + qc = QuantumCircuit(5) + qc.h(0) + qc.cx(0, range(1, 5)) + pm = generate_preset_pass_manager(2, coupling_map=cm) + pm.init += StarPreRouting() + result = pm.run(qc) + result.draw("mpl") + ``` + + ![\_images/release\_notes-7.png](/images/api/qiskit/release_notes-7.png) + + + +### Visualization Features + +* The text and [Matplotlib](https://matplotlib.org) circuit drawers ([`QuantumCircuit.draw()`](/api/qiskit/qiskit.circuit.QuantumCircuit#draw "qiskit.circuit.QuantumCircuit.draw")) have minimal support for displaying expressions involving manual real-time variables. The [`Store`](/api/qiskit/circuit#qiskit.circuit.Store "qiskit.circuit.Store") operation and the variable initializations are not yet supported; for large-scale dynamic circuits, we recommend using the OpenQASM 3 export capabilities ([`qasm3.dumps()`](/api/qiskit/qasm3#qiskit.qasm3.dumps "qiskit.qasm3.dumps")) to get a textual representation of a circuit. + + + +### Misc. Features + +* This release of Qiskit finalizes support for NumPy 2.0. Qiskit will continue to support both NumPy 1.x and 2.x for the foreseeable future. + + + +### Upgrade Notes + +* Removes the hard-coding of style options for [`plot_histogram()`](/api/qiskit/qiskit.visualization.plot_histogram "qiskit.visualization.plot_histogram"). This allows Matplotlib style files to be faithfully applied to the figures. Users looking to go beyond the defaults set by Matplotlib can make their own style files, or pass a Matplotlib `Axes` object to `plot_histogram` and post-apply any customizations. + +* The [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function has been upgraded to internally convert backend inputs of type [`BackendV1`](/api/qiskit/qiskit.providers.BackendV1 "qiskit.providers.BackendV1") to [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "qiskit.providers.BackendV2"), which allows the transpilation pipeline to now access the backend constraints through a [`Target`](/api/qiskit/qiskit.transpiler.Target "qiskit.transpiler.Target"). This change does not require any user action. + + + +### Circuits Upgrade Notes + +* The random-number usage of [`QuantumVolume`](/api/qiskit/qiskit.circuit.library.QuantumVolume "qiskit.circuit.library.QuantumVolume") has changed, so you will get a different circuit for a fixed seed between older versions of Qiskit and this version. The random-unitary generation now uses more bits of entropy, so large circuits will be less biased. + +* The internal [`UnitaryGate`](/api/qiskit/qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate") instances in the definition of a [`QuantumVolume`](/api/qiskit/qiskit.circuit.library.QuantumVolume "qiskit.circuit.library.QuantumVolume") circuit will no longer have a [`label`](/api/qiskit/qiskit.circuit.Instruction#label "qiskit.circuit.Instruction.label") field set. Previously this was set to the string `su4_` where `` was a three-digit number denoting the seed of an internal Numpy pRNG instance for that gate. Doing this was a serious performance problem, and the seed ought not to have been useful; if you need to retrieve the matrix from the gate, simply use the [`Gate.to_matrix()`](/api/qiskit/qiskit.circuit.Gate#to_matrix "qiskit.circuit.Gate.to_matrix") method. + + + +### Primitives Upgrade Notes + +* The function `make_data_bin()` no longer creates and returns a [`DataBin`](/api/qiskit/qiskit.primitives.DataBin "qiskit.primitives.DataBin") subclass. It instead always returns the [`DataBin`](/api/qiskit/qiskit.primitives.DataBin "qiskit.primitives.DataBin") class. However, it continues to exist for backwards compatibility, though will eventually be deprecated. All users should migrate to construct [`DataBin`](/api/qiskit/qiskit.primitives.DataBin "qiskit.primitives.DataBin") instances directly, instead of instantiating subclasses as output by `make_data_bin()`. + + + +### Providers Upgrade Notes + +* Implementations of [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "qiskit.providers.BackendV2") (and [`BackendV1`](/api/qiskit/qiskit.providers.BackendV1 "qiskit.providers.BackendV1")) may desire to update their [`run()`](/api/qiskit/qiskit.providers.BackendV2#run "qiskit.providers.BackendV2.run") methods to eagerly reject inputs containing typed classical variables (see [`qiskit.circuit.classical`](/api/qiskit/circuit_classical#module-qiskit.circuit.classical "qiskit.circuit.classical")) and the [`Store`](/api/qiskit/circuit#qiskit.circuit.Store "qiskit.circuit.Store") instruction, if they do not have support for them. The new [`Store`](/api/qiskit/circuit#qiskit.circuit.Store "qiskit.circuit.Store") instruction is treated by the transpiler as an always-available “directive” (like [`Barrier`](/api/qiskit/circuit#qiskit.circuit.Barrier "qiskit.circuit.Barrier")); if your backends do not support this won’t be caught by the [`transpiler`](/api/qiskit/transpiler#module-qiskit.transpiler "qiskit.transpiler"). + + See [Real-time variables](/api/qiskit/providers#providers-guide-real-time-variables) for more information. + + + +### QPY Upgrade Notes + +* The value of [`qiskit.qpy.QPY_VERSION`](/api/qiskit/qpy#qiskit.qpy.QPY_VERSION "qiskit.qpy.QPY_VERSION") is now 12. [`QPY_COMPATIBILITY_VERSION`](/api/qiskit/qpy#qiskit.qpy.QPY_COMPATIBILITY_VERSION "qiskit.qpy.QPY_COMPATIBILITY_VERSION") is unchanged at 10. + + + +### Synthesis Upgrade Notes + +* The [`TwoQubitWeylDecomposition`](/api/qiskit/qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.TwoQubitWeylDecomposition") no longer will self-specialize into a subclass on creation. This was an internal detail of the [`TwoQubitWeylDecomposition`](/api/qiskit/qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.TwoQubitWeylDecomposition") previously, and was not a documented public behavior as all the subclasses behaved the same and were only used for internal dispatch. However, as it was discoverable behavior this release note is to document that this will no longer occur and all instances of [`TwoQubitWeylDecomposition`](/api/qiskit/qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.TwoQubitWeylDecomposition") will be of the same type. There is no change in behavior for public methods of the class. + + + +### Transpiler Upgrade Notes + +* The preset [`StagedPassManager`](/api/qiskit/qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager") returned for optimization level 2 by [`generate_preset_pass_manager()`](/api/qiskit/transpiler_preset#qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager "qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager") and [`level_2_pass_manager()`](/api/qiskit/transpiler_preset#qiskit.transpiler.preset_passmanagers.level_2_pass_manager "qiskit.transpiler.preset_passmanagers.level_2_pass_manager") have been reworked to provide a better balance between runtime and optimization. This means the output circuits will change compared to earlier releases. If you need an exact pass manager from level 2 in earlier releases you can either build it manually or use it from an earlier release and save the circuits with [`qpy`](/api/qiskit/qpy#module-qiskit.qpy "qiskit.qpy") to load with a newer release. + + + +### Misc. Upgrade Notes + +* The minimum supported version of Windows is now Windows 10. In previous releases we did not explicitly list a minimum supported version of Windows and implicitly Windows 7, 8, and 8.1 may have worked (but were never tested). But due to Rust 1.78 dropping support for older versions of Windows Qiskit’s published binaries on PyPI will not support older versions of Windows starting with this release. If you’re using an older version of Windows you can likely still build Qiskit from source using an older Rust compiler (Qiskit’s minimum supported Rust version for building from source is currently 1.70) but older versions of Windows are not a supported platform and are untested. + + + +### Deprecation Notes + +* Support for running Qiskit with Python 3.8 has been deprecated and will be removed in the Qiskit 1.3.0 release. The 1.3.0 is the first release after Python 3.8 goes end of life and is no longer supported. \[1] This means that starting in the 1.3.0 release you will need to upgrade the Python version you’re using to Python 3.9 or above. + + \[1] [https://devguide.python.org/versions/](https://devguide.python.org/versions/) + + + +### Providers Deprecations + +* The abstract base classes `Provider` and `ProviderV1` are now deprecated and will be removed in Qiskit 2.0.0. The abstraction offered by these interface definitions were not providing a substantial value; it solely encapsulated the attributes `name`, `backends`, and a `get_backend()`. A \_provider\_, as a concept, will continue existing as a collection of backends. If you’re implementing a provider currently you can adjust your code by simply removing `ProviderV1` as the parent class of your implementation. As part of this you probably would want to add an implementation of `get_backend` for backwards compatibility. For example: + + ```python + def get_backend(self, name=None, **kwargs): + backend = self.backends(name, **kwargs) + if len(backends) > 1: + raise QiskitBackendNotFoundError("More than one backend matches the criteria") + if not backends: + raise QiskitBackendNotFoundError("No backend matches the criteria") + return backends[0] + ``` + + + +### Synthesis Deprecations + +* The [`TwoQubitWeylDecomposition.specialize()`](/api/qiskit/qiskit.synthesis.TwoQubitWeylDecomposition#specialize "qiskit.synthesis.TwoQubitWeylDecomposition.specialize") method is now deprecated and will be removed in the Qiskit 2.0.0 release. This method never had a public purpose and was unsafe for an end user to call as it would mutate the calculated decomposition in the object and produce invalid fields in the object. It was only used internally to construct a new [`TwoQubitWeylDecomposition`](/api/qiskit/qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.TwoQubitWeylDecomposition") object. Despite this it was still a documented part of the public API for the class and is now being deprecated without any potential replacement. This release it always will raise a `NotImplementedError` when called because the specialization subclassing has been removed as part of the Rust rewrite of the class. + + + +### Transpiler Deprecations + +* The pass `qiskit.transpiler.passes.CXCancellation` was deprecated in favor of [`InverseCancellation`](/api/qiskit/qiskit.transpiler.passes.InverseCancellation "qiskit.transpiler.passes.InverseCancellation"), which is more generic. `CXCancellation` is fully semantically equivalent to `InverseCancellation([CXGate()])`. + +* The transpilation pass `qiskit.transpiler.passes.ALAPSchedule` is now deprecated. It was pending for deprecation since Qiskit 0.37 (with Terra 0.21), released on June 2022. The pass is replaced by [`ALAPScheduleAnalysis`](/api/qiskit/qiskit.transpiler.passes.ALAPScheduleAnalysis "qiskit.transpiler.passes.ALAPScheduleAnalysis"), which is an analysis pass. + +* The transpilation pass `qiskit.transpiler.passes.ASAPSchedule` is now deprecated. It was pending for deprecation since Qiskit 0.37 (with Terra 0.21), released on June 2022. It has been superseded by [`ASAPScheduleAnalysis`](/api/qiskit/qiskit.transpiler.passes.ASAPScheduleAnalysis "qiskit.transpiler.passes.ASAPScheduleAnalysis") and the new scheduling workflow. + +* The transpilation pass `qiskit.transpiler.passes.DynamicalDecoupling` is now deprecated. It was pending for deprecation since Qiskit 0.37 (with Terra 0.21), released on June 2022. Instead, use [`PadDynamicalDecoupling`](/api/qiskit/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. + +* The transpilation pass `qiskit.transpiler.passes.AlignMeasures` is now deprecated. It was pending for deprecation since Qiskit 0.37 (with Terra 0.21), released on June 2022. Instead, use [`ConstrainedReschedule`](/api/qiskit/qiskit.transpiler.passes.ConstrainedReschedule "qiskit.transpiler.passes.ConstrainedReschedule"), which performs the same function and also supports aligning to additional timing constraints. + + + +### Visualization Deprecations + +* The parameters `show_idle` and `show_barrier` in the timeline drawers had been replaced by `idle_wires` and `plot_barriers` respectively to match the circuit drawer parameters. Their previous names are now deprecated and will be removed in the next major release. The new parameters are fully equivalent. + + + +### Bug Fixes + +* Fixed an issue with the [`qpy.dump()`](/api/qiskit/qpy#qiskit.qpy.dump "qiskit.qpy.dump") function where, when the `use_symengine` flag was set to a truthy object that evaluated to `True` but was not actually the boolean `True`, the generated QPY payload would be corrupt. For example, if you set `use_symengine` to [`HAS_SYMENGINE`](/api/qiskit/utils#qiskit.utils.optionals.HAS_SYMENGINE "qiskit.utils.optionals.HAS_SYMENGINE"), this object evaluates to `True` when cast as a bool, but isn’t actually `True`. + +* Fixed an issue with the [`circuit_drawer()`](/api/qiskit/qiskit.visualization.circuit_drawer "qiskit.visualization.circuit_drawer") function and [`QuantumCircuit.draw()`](/api/qiskit/qiskit.circuit.QuantumCircuit#draw "qiskit.circuit.QuantumCircuit.draw") method when loading a matplotlib style via the user configuration file. + +* Fixed an issue where the [`ConstrainedReschedule`](/api/qiskit/qiskit.transpiler.passes.ConstrainedReschedule "qiskit.transpiler.passes.ConstrainedReschedule") transpiler pass would previously error if the circuit contained a [`Reset`](/api/qiskit/circuit#qiskit.circuit.Reset "qiskit.circuit.Reset") instruction. This has been corrected so that the pass no longer errors, however an actual hardware may behave differently from what Qiskit scheduler assumes especially for mid-circuit measurements and resets. Qiskit scheduler raises `RuntimeWarning` if it encounters circuit containing either. Fixed [#10354](https://github.com/Qiskit/qiskit/issues/10354) + +* Fixed an issue with the `CommutationChecker` class where it would error if a gate’s [`name`](/api/qiskit/qiskit.circuit.Gate#name "qiskit.circuit.Gate.name") attribute was UTF8 encoded. Previously only gate names with ascii encoding would work. Fixed [#12501](https://github.com/Qiskit/qiskit/issues/12051) + +* Fixed an issue with the [`SparsePauliOp.apply_layout()`](/api/qiskit/qiskit.quantum_info.SparsePauliOp#apply_layout "qiskit.quantum_info.SparsePauliOp.apply_layout") and [`Pauli.apply_layout()`](/api/qiskit/qiskit.quantum_info.Pauli#apply_layout "qiskit.quantum_info.Pauli.apply_layout") methods when an invalid array with duplicate or negative indices were passed in for the `layout` argument. Previously this wouldn’t result in an error and the transformation performed would not be valid. These methods will now raise a [`QiskitError`](/api/qiskit/exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") if duplicate indices or negative indices are provided as part of a layout. + +* Fixed a performance issue in the [`BackendSamplerV2`](/api/qiskit/qiskit.primitives.BackendSamplerV2 "qiskit.primitives.BackendSamplerV2") and [`BackendEstimatorV2`](/api/qiskit/qiskit.primitives.BackendEstimatorV2 "qiskit.primitives.BackendEstimatorV2"). Fixed [#12290](https://github.com/Qiskit/qiskit-terra/issues/12290) + +* Fixed an issue with the [`convert_to_target()`](/api/qiskit/qiskit.providers.convert_to_target "qiskit.providers.convert_to_target") where the converter would incorrectly ignore control flow instructions if they were specified in the `BackendConfiguration.supported_instructions` attribute which is the typical location that control flow instructions are specified in a [`BackendConfiguration`](/api/qiskit/qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") object. Fixed [#11872](https://github.com/Qiskit/qiskit/issues/11872). + +* Fixed an issue with the [`circuit_drawer()`](/api/qiskit/qiskit.visualization.circuit_drawer "qiskit.visualization.circuit_drawer") or [`QuantumCircuit.draw()`](/api/qiskit/qiskit.circuit.QuantumCircuit#draw "qiskit.circuit.QuantumCircuit.draw") when using the `mpl` output option where the program would hang if the circuit being drawn had a ControlFlow operation in it and the `fold` option was set to -1 (meaning no fold). Fixed [#12012](https://github.com/Qiskit/qiskit/issues/12012). + +* Fixed a bug in the conversion of custom pulse instructions to the legacy [`qiskit.qobj`](/api/qiskit/qobj#module-qiskit.qobj "qiskit.qobj") format. The bug was introduced in Qiskit 1.0.0 and caused conversion of instructions with custom pulse shapes to raise an error. After the fix, the conversion is carried out correctly, and the custom pulse is converted to [`Waveform`](/api/qiskit/qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform") as it should. Fixed [#11828](https://github.com/Qiskit/qiskit/issues/11828). + +* A bug in [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") has been fixed where custom `instruction_durations`, `dt` and `backend_properties` constraints would be ignored when provided at the same time as a backend of type [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "qiskit.providers.BackendV2"). The behavior after the fix is now independent of whether the provided backend is of type [`BackendV1`](/api/qiskit/qiskit.providers.BackendV1 "qiskit.providers.BackendV1") or type [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "qiskit.providers.BackendV2"). Similarly, custom `timing_constraints` are now overridden by `target` inputs but take precedence over [`BackendV1`](/api/qiskit/qiskit.providers.BackendV1 "qiskit.providers.BackendV1") and [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "qiskit.providers.BackendV2") inputs. + +* Calling [`EquivalenceLibrary.set_entry()`](/api/qiskit/qiskit.circuit.EquivalenceLibrary#set_entry "qiskit.circuit.EquivalenceLibrary.set_entry") will now correctly update the internal graph object of the library. Previously, the metadata would be updated, but the graph structure would be unaltered, meaning that users like [`BasisTranslator`](/api/qiskit/qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator") would still use the old rules. Fixed [#11958](https://github.com/Qiskit/qiskit/issues/11958). + +* The [`EvolvedOperatorAnsatz`](/api/qiskit/qiskit.circuit.library.EvolvedOperatorAnsatz "qiskit.circuit.library.EvolvedOperatorAnsatz") now correctly handles the case where the operators argument is an empty list. Previously, this would result in an error. + +* From now on, [`EvolvedOperatorAnsatz`](/api/qiskit/qiskit.circuit.library.EvolvedOperatorAnsatz "qiskit.circuit.library.EvolvedOperatorAnsatz") will not have any qregs when thera are zero qubits, instead of having a [`QuantumRegister`](/api/qiskit/circuit#qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") instance with zero qubits. This behavior aligns more consistently with its superclass [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + +* The method [`Instruction.repeat()`](/api/qiskit/qiskit.circuit.Instruction#repeat "qiskit.circuit.Instruction.repeat") now moves a set [`condition`](/api/qiskit/qiskit.circuit.Instruction#condition "qiskit.circuit.Instruction.condition") to the outer returned [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "qiskit.circuit.Instruction") and leave the inner gates of its definition unconditional. Previously, the method would leave [`ClassicalRegister`](/api/qiskit/circuit#qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") instances within the inner definition, which was an invalid state, and would manifest itself as seemingly unrelated bugs later, such as during transpilation or export. Fixed [#11935](https://github.com/Qiskit/qiskit/issues/11935). + +* Fixed an issue in the [`InverseCancellation`](/api/qiskit/qiskit.transpiler.passes.InverseCancellation "qiskit.transpiler.passes.InverseCancellation") transpiler pass where in some cases it would incorrectly cancel a self-inverse parameterized gate even if the parameter value didn’t match. Fixed [#11815](https://github.com/Qiskit/qiskit/issues/11815) + +* Improve the decomposition of the gates [`MCXGate`](/api/qiskit/qiskit.circuit.library.MCXGate "qiskit.circuit.library.MCXGate") and [`MCPhaseGate`](/api/qiskit/qiskit.circuit.library.MCPhaseGate "qiskit.circuit.library.MCPhaseGate") without using ancilla qubits, so that the number of [`CXGate`](/api/qiskit/qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate") will grow quadratically in the number of qubits and not exponentially. + +* A bug that crashes the [`convert_to_target()`](/api/qiskit/qiskit.providers.convert_to_target "qiskit.providers.convert_to_target") function when qubit properties (either T1, T2 or frequency) are missing was fixed. The missing property values in [`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") are filled with `None`. + +* [`BasePassManager.run()`](/api/qiskit/qiskit.passmanager.BasePassManager#run "qiskit.passmanager.BasePassManager.run") will no longer leak the previous [`PropertySet`](/api/qiskit/qiskit.passmanager.PropertySet "qiskit.passmanager.PropertySet") into new workflows when called more than once. Previously, the same [`PropertySet`](/api/qiskit/qiskit.passmanager.PropertySet "qiskit.passmanager.PropertySet") as before would be used to initialize follow-on runs, which could mean that invalid property information was being given to tasks. The behavior now matches that of Qiskit 0.44. Fixed [#11784](https://github.com/Qiskit/qiskit/issues/11784). + +* [`Pauli.evolve()`](/api/qiskit/qiskit.quantum_info.Pauli#evolve "qiskit.quantum_info.Pauli.evolve") now correctly handles quantum circuits containing ECR gates. Formerly they were not recognized as Clifford gates, and an error was raised. + +* Fixed a bug in [`Pauli.evolve()`](/api/qiskit/qiskit.quantum_info.Pauli#evolve "qiskit.quantum_info.Pauli.evolve") where evolving by a circuit with a name matching certain Clifford gates (‘cx’, ‘cz’, etc) would evolve the Pauli according to the name of the circuit, not by the contents of the circuit. This bug occurred only with the non-default option `frame='s'`. + +* Fixed a performance issue in the [`qpy.load()`](/api/qiskit/qpy#qiskit.qpy.load "qiskit.qpy.load") function when deserializing QPY payloads with large numbers of qubits or clbits in a circuit. + +* Fixed a bug in the handling of `default_alignment` argument of [`build()`](/api/qiskit/pulse#qiskit.pulse.builder.build "qiskit.pulse.builder.build"). Inputs of type [`AlignmentKind`](/api/qiskit/pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.AlignmentKind") are now correctly processed as default alignments. + +* Fixed a bug in `qiskit.pulse.utils.format_parameter_value()` function that unintentionally converts large enough integer numbers into float values or causes unexpected rounding. See [#11971](https://github.com/Qiskit/qiskit/issues/11971) for details. + +* Fix an issue in the [`QDrift`](/api/qiskit/qiskit.synthesis.QDrift "qiskit.synthesis.QDrift") class where the coefficients of the Hamiltonian were previously force to be positive by taking the absolute value of each coefficient. This has been corrected so that the negative coeffients’ signs are added back. + +* A bug has been fixed in `convert_durations_to_dt()` where the function would blindly apply a conversion from seconds to `dt` on circuit durations, independently of the original units of the attribute. This could lead to wrong orders of magnitude in the reported circuit durations. + +* Fixed [`SparsePauliOp.apply_layout()`](/api/qiskit/qiskit.quantum_info.SparsePauliOp#apply_layout "qiskit.quantum_info.SparsePauliOp.apply_layout") to work correctly with zero-qubit operators. For example, if you previously created a 0 qubit and applied a layout like: + + ```python + op = SparsePauliOp("") + op.apply_layout(None, 3) + ``` + + this would have previously raised an error. Now this will correctly return an operator of the form: `SparsePauliOp(['III'], coeffs=[1.+0.j])` + +* Fixed an oversight in the [`Commuting2qGateRouter`](/api/qiskit/qiskit.transpiler.passes.Commuting2qGateRouter "qiskit.transpiler.passes.Commuting2qGateRouter") transpiler pass where the qreg permutations were not added to the pass property set, so they would have to be tracked manually by the user. Now it’s possible to access the permutation through the output circuit’s `layout` property and plug the pass into any transpilation pipeline without loss of information. + +* Fixed a floating-point imprecision when scaling certain pulse units between seconds and nanoseconds. If the pulse was symbolically defined, an unnecessary floating-point error could be introduced by the scaling for certain builds of `symengine`, which could manifest in unexpected results once the symbols were fully bound. Fixed [#12392](https://github.com/Qiskit/qiskit/pull/12392). + +* The preset pass managers of [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") will no longer fail on circuits with control flow, if no hardware target or basis-gate set is specified. They will now treat such abstract targets as permitting all control-flow operations. Fixed [#11906](https://github.com/Qiskit/qiskit/issues/11906). + +* The method `qiskit.instruction.Instruction.soft_compare()` is meant to compare whether two gates match in their name, number of qubits, number of clbits, and the number of parameters. However, there was a typo where it would not check the number of qubits and number of clbits for a match. This resolves the apparent typo. + +* The default `init` plugin was not properly raising a [`TranspilerError`](/api/qiskit/transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") when called with an invalid optimization level. + +* Fixed an issue with the [`Operator.from_circuit()`](/api/qiskit/qiskit.quantum_info.Operator#from_circuit "qiskit.quantum_info.Operator.from_circuit") constructor method where it would incorrectly interpret the final layout permutation resulting in an invalid [`Operator`](/api/qiskit/qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") being constructed. Previously, the final layout was processed without regards for the initial layout, i.e. the initialization was incorrect for all quantum circuits that have a non-trivial initial layout. + +* Fixed a performance issue in [`PassManager.run()`](/api/qiskit/qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") when it is running over multiple circuits in parallel. It will no longer spend time serializing the [`PassManager`](/api/qiskit/qiskit.transpiler.PassManager "qiskit.transpiler.passmanager.PassManager") (which is a requirement for parallel execution) when given multiple inputs if it is only going to process the inputs serially. + +* [`Parameter`](/api/qiskit/qiskit.circuit.Parameter "qiskit.circuit.Parameter") was updated so that instances that compare equal always have the same hash. Previously, only the [`Parameter.uuid`](/api/qiskit/qiskit.circuit.Parameter#uuid "qiskit.circuit.Parameter.uuid") was compared, so [`Parameter`](/api/qiskit/qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances with different names could compare equal if they had been constructed using a common value for the `uuid` parameter (which is usually not passed explicitly). + +* Fixed a bug in `plot_coupling_map()` that caused the edges of the coupling map to be colored incorrectly. Fixed [#12369](https://github.com/Qiskit/qiskit/pull/12369). + +* The OpenQASM 2.0 parser ([`qasm2.load()`](/api/qiskit/qasm2#qiskit.qasm2.load "qiskit.qasm2.load") and [`qasm2.loads()`](/api/qiskit/qasm2#qiskit.qasm2.loads "qiskit.qasm2.loads")) can now evaluate gate-angle expressions including integer operands that would overflow the system-size integer. These will be evaluated in a double-precision floating-point context, just like the rest of the expression always has been. However, an arbitrarily large integer will not necessarily be exactly representable in double-precision floating-point, so there is a chance that however the circuit was generated, it had already lost all numerical precision modulo $2\pi$. + +* [`Parameter`](/api/qiskit/qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances used as stand-ins for `input` variables in OpenQASM 3 programs will now have their names escaped to avoid collisions with built-in gates during the export to OpenQASM 3. Previously there could be a naming clash, and the exporter would generate invalid OpenQASM 3. + +* Fixed bug in [`QuantumCircuit.draw()`](/api/qiskit/qiskit.circuit.QuantumCircuit#draw "qiskit.circuit.QuantumCircuit.draw") that was causing custom style dictionaries for the Matplotlib drawer to be modified upon execution. + +* [`QuantumCircuit.append()`](/api/qiskit/qiskit.circuit.QuantumCircuit#append "qiskit.circuit.QuantumCircuit.append") with `copy=True` (its default) will now correctly copy instructions parametrized by [`ParameterExpression`](/api/qiskit/qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") instances, and not just by [`Parameter`](/api/qiskit/qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances. + +* The internal handling of custom circuit calibrations and [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") has been offloaded from the [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function to the individual transpiler passes: `DynamicalDecoupling`, `DynamicalDecoupling`. Before, instruction durations from circuit calibrations would not be taken into account unless they were manually incorporated into instruction\_durations input argument, but the passes that need it now analyze the circuit and pick the most relevant duration value according to the following priority order: target > custom input > circuit calibrations. + +* Fixed a bug in [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") where the `num_processes` argument would only be used if `dt` or `instruction_durations` were provided. + + + +### Other Notes + +* Support for the arm64 macOS platform has been promoted from Tier 3 to Tier 1. Previously the platform was at Tier 3 because there was no available CI environment for testing Qiskit on the platform. Now that Github has made an arm64 macOS environment available to open source projects [\[1\]](#id3) we’re testing the platform along with the other Tier 1 supported platforms. + + \[[1](#id2)] + + [https://github.blog/changelog/2024-01-30-github-actions-introducing-the-new-m1-macos-runner-available-to-open-source/](https://github.blog/changelog/2024-01-30-github-actions-introducing-the-new-m1-macos-runner-available-to-open-source/) + + + + + +## 1.0.0rc1 + + + + + +### Providers Upgrade Notes + +* The deprecated [`qiskit.providers.fake_provider`](/api/qiskit/providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider") module has been migrated to the `qiskit-ibm-runtime` Python package. For this reason, the following elements in the [`qiskit.providers.fake_provider`](/api/qiskit/providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider") have been removed following their deprecation in Qiskit 0.46: + + > * `qiskit.providers.fake_provider.FakeProvider` + > * `qiskit.providers.fake_provider.FakeProviderForBackendV2` + > * `qiskit.providers.fake_provider.FakeProviderFactory` + > * `qiskit.providers.fake_provider.fake_backends.FakeBackendV2` + > * any fake backend contained in `qiskit.providers.fake_provider.backends` (accessible through the provider) + > * `qiskit.providers.fake_provider.FakeQasmSimulator` + > * `qiskit.providers.fake_provider.FakeJob` + > * `qiskit.providers.fake_provider.FakeQobj` + + To use the new fake provider module, you can run `pip install qiskit-ibm-runtime` and replace the qiskit import path (`qiskit.providers.fake_provider`) with the new import path (`qiskit_ibm_runtime.fake_provider`). Migration example: + + ```python + # Legacy path + from qiskit.providers.fake_provider import FakeProvider, FakeSherbrooke + backend1 = FakeProvider().get_backend("fake_ourense") + backend2 = FakeSherbrooke() + + # New path + # run "pip install qiskit-ibm-runtime" + from qiskit_ibm_runtime.fake_provider import FakeProvider, FakeSherbrooke + backend1 = FakeProvider().get_backend("fake_ourense") + backend2 = FakeSherbrooke() + ``` + + Additionally, the following fake backends designed for special testing purposes have been superseded by the new [`GenericBackendV2`](/api/qiskit/qiskit.providers.fake_provider.GenericBackendV2 "qiskit.providers.fake_provider.GenericBackendV2") class, and are also removed following their deprecation in Qiskit 0.46: + + > * `qiskit.providers.fake_provider.fake_backend_v2.FakeBackendV2` + > * `` `qiskit.providers.fake_provider.fake_backend_v2.FakeBackendV2LegacyQubitProps `` + > * `qiskit.providers.fake_provider.fake_backend_v2.FakeBackend5QV2` + > * `qiskit.providers.fake_provider.fake_backend_v2.FakeBackendSimple` + + Migration example to the new [`GenericBackendV2`](/api/qiskit/qiskit.providers.fake_provider.GenericBackendV2 "qiskit.providers.fake_provider.GenericBackendV2") class: + + ```python + # Legacy path + from qiskit.providers.fake_provider import FakeBackend5QV2 + backend = FakeBackend5QV2() + + # New path + from qiskit.providers.fake_provider import GenericBackendV2 + backend = GenericBackendV2(num_qubits=5) + # note that this class will generate 5q backend with generic + # properties that serves the same purpose as FakeBackend5QV2 + # but will generate different results + ``` + diff --git a/docs/api/qiskit/release-notes/index.mdx b/docs/api/qiskit/release-notes/index.mdx index 3f3499e6e11..2eb5cf68fc1 100644 --- a/docs/api/qiskit/release-notes/index.mdx +++ b/docs/api/qiskit/release-notes/index.mdx @@ -9,6 +9,7 @@ New features, bug fixes, and other changes in previous versions of Qiskit SDK. ## Release notes by version +* [1.1](./1.1) * [1.0](./1.0) * [0.46](./0.46) * [0.45](./0.45) diff --git a/docs/api/qiskit/result.mdx b/docs/api/qiskit/result.mdx index 403623de8e9..0c65b7ac2c5 100644 --- a/docs/api/qiskit/result.mdx +++ b/docs/api/qiskit/result.mdx @@ -18,15 +18,19 @@ python_api_name: qiskit.result `qiskit.result` +## Core classes + | | | | ----------------------------------------------------------------------------------------------------- | ---------------------------------------------------------- | | [`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. | +## Marginalization + ### marginal\_counts - + Marginalize counts from an experiment over some indices of interest. **Parameters** @@ -54,7 +58,7 @@ python_api_name: qiskit.result ### marginal\_distribution - + 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. @@ -81,7 +85,7 @@ python_api_name: qiskit.result ### marginal\_memory - + 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. @@ -119,7 +123,7 @@ python_api_name: qiskit.result ### sampled\_expectation\_value - + Computes expectation value from a sampled distribution Note that passing a raw dict requires bit-string keys. diff --git a/docs/api/qiskit/scheduler.mdx b/docs/api/qiskit/scheduler.mdx index 1701e9b704b..5e3cf919405 100644 --- a/docs/api/qiskit/scheduler.mdx +++ b/docs/api/qiskit/scheduler.mdx @@ -20,9 +20,11 @@ python_api_name: qiskit.scheduler A circuit scheduler compiles a circuit program to a pulse program. +## Core API + ### ScheduleConfig - + Configuration for pulse scheduling. Container for information needed to schedule a QuantumCircuit into a pulse Schedule. @@ -36,7 +38,7 @@ A circuit scheduler compiles a circuit program to a pulse program. ### schedule\_circuit - + 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: @@ -64,13 +66,11 @@ A circuit scheduler compiles a circuit program to a pulse program. [*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") - - -Pulse scheduling methods. +## Pulse scheduling methods ### as\_soon\_as\_possible - + 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. @@ -92,7 +92,7 @@ Pulse scheduling methods. ### as\_late\_as\_possible - + 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. diff --git a/docs/api/qiskit/synthesis.mdx b/docs/api/qiskit/synthesis.mdx index bcea081d130..f644d9ea739 100644 --- a/docs/api/qiskit/synthesis.mdx +++ b/docs/api/qiskit/synthesis.mdx @@ -35,7 +35,7 @@ python_api_name: qiskit.synthesis ### synth\_cnot\_count\_full\_pmh - + 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 \times n$ matrix. @@ -43,7 +43,7 @@ python_api_name: qiskit.synthesis **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)")*\[*[*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*]] | np.ndarray\[*[*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*]*) – $n \times 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 the number of qubits. + * **section\_size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The size of each section in the Patel–Markov–Hayes algorithm \[1]. **Returns** @@ -64,7 +64,7 @@ python_api_name: qiskit.synthesis ### synth\_cnot\_depth\_line\_kms - + Synthesize linear reversible circuit for linear nearest-neighbor architectures using Kutin, Moulton, Smithline method. Synthesis algorithm for linear reversible circuits from \[1], section 7. This algorithm synthesizes any linear reversible circuit of $n$ qubits over a linear nearest-neighbor architecture using CX gates with depth at most $5n$. @@ -94,7 +94,7 @@ python_api_name: qiskit.synthesis ### synth\_cz\_depth\_line\_mr - + 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 [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate")s and phase gates ([`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate"), [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate") or [`ZGate`](qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate")). @@ -118,7 +118,7 @@ python_api_name: qiskit.synthesis ### synth\_cx\_cz\_depth\_line\_my - + 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** @@ -142,7 +142,7 @@ python_api_name: qiskit.synthesis ### synth\_cnot\_phase\_aam - + 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, `cx` gates are applied so that a designated target bit contains the (partial) parity $\chi_y(x)$ where $y_i = 1$ if and only if $y'_i = 1$ for all $y' \in S$. If $S$ contains a single element $\{y'\}$, then $y = y'$, and the target bit contains the value $\chi_{y'}(x)$ as desired. @@ -195,7 +195,7 @@ python_api_name: qiskit.synthesis ### synth\_permutation\_depth\_lnn\_kms - + Synthesize a permutation circuit for a linear nearest-neighbor architecture using the Kutin, Moulton, Smithline method. This is the permutation synthesis algorithm from \[1], section 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). @@ -219,7 +219,7 @@ python_api_name: qiskit.synthesis ### synth\_permutation\_basic - + 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. @@ -239,7 +239,7 @@ python_api_name: qiskit.synthesis ### synth\_permutation\_acg - + 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). @@ -264,11 +264,35 @@ python_api_name: qiskit.synthesis 2. N. Alon, F. R. K. Chung, and R. L. Graham. *Routing Permutations on Graphs Via Matchings.*, [(Full paper)](https://www.cs.tau.ac.il/~nogaa/PDFS/r.pdf) +### synth\_permutation\_reverse\_lnn\_kms + + + Synthesize reverse permutation for linear nearest-neighbor architectures using Kutin, Moulton, Smithline method. + + Synthesis algorithm for reverse permutation from \[1], section 5. This algorithm synthesizes the reverse permutation on $n$ qubits over a linear nearest-neighbor architecture using CX gates with depth $2 * n + 2$. + + **Parameters** + + **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits. + + **Returns** + + The synthesized quantum circuit. + + **Return type** + + [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + + **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) + + ## Clifford Synthesis ### synth\_clifford\_full - + Decompose a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") operator into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). For $N \leq 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]. @@ -295,7 +319,7 @@ python_api_name: qiskit.synthesis ### synth\_clifford\_ag - + Decompose a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") operator into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") based on Aaronson-Gottesman method \[1]. **Parameters** @@ -317,7 +341,7 @@ python_api_name: qiskit.synthesis ### synth\_clifford\_bm - + Optimal CX-cost decomposition of a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") operator on 2 qubits or 3 qubits into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") based on the Bravyi-Maslov method \[1]. **Parameters** @@ -343,7 +367,7 @@ python_api_name: qiskit.synthesis ### synth\_clifford\_greedy - + Decompose a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") operator into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") based on the greedy Clifford compiler that is described in Appendix A of Bravyi, Hu, Maslov and Shaydulin \[1]. This method typically yields better CX cost compared to the Aaronson-Gottesman method. @@ -373,7 +397,7 @@ python_api_name: qiskit.synthesis ### synth\_clifford\_layers - + Synthesis of a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") into layers, it provides a similar decomposition to the synthesis described in Lemma 8 of Bravyi and Maslov \[1]. For example, a 5-qubit Clifford circuit is decomposed into the following layers: @@ -418,7 +442,7 @@ python_api_name: qiskit.synthesis ### synth\_clifford\_depth\_lnn - + Synthesis of a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") into layers for linear-nearest neighbour connectivity. The depth of the synthesized n-qubit circuit is bounded by $7n+2$, which is not optimal. It should be replaced by a better algorithm that provides depth bounded by $7n-4$ \[3]. @@ -446,7 +470,7 @@ python_api_name: qiskit.synthesis ### synth\_cnotdihedral\_full - + Decompose a [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") element into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). For $N \leq 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]. @@ -471,7 +495,7 @@ python_api_name: qiskit.synthesis ### synth\_cnotdihedral\_two\_qubits - + Decompose a [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") element on a single qubit and two qubits into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). This decomposition has an optimal number of [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate")s. **Parameters** @@ -497,7 +521,7 @@ python_api_name: qiskit.synthesis ### synth\_cnotdihedral\_general - + Decompose a [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") element into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). Decompose a general [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") elements. The number of CX gates is not necessarily optimal. For a decomposition of a 1-qubit or 2-qubit element, call [`synth_cnotdihedral_two_qubits()`](#qiskit.synthesis.synth_cnotdihedral_two_qubits "qiskit.synthesis.synth_cnotdihedral_two_qubits"). @@ -527,7 +551,7 @@ python_api_name: qiskit.synthesis ### synth\_stabilizer\_layers - + Synthesis of a stabilizer state into layers. It provides a similar decomposition to the synthesis described in Lemma 8 of reference \[1], without the initial Hadamard-free sub-circuit which do not affect the stabilizer state. @@ -574,7 +598,7 @@ python_api_name: qiskit.synthesis ### synth\_stabilizer\_depth\_lnn - + Synthesis of an n-qubit stabilizer state for linear-nearest neighbour connectivity, in 2-qubit depth $2n+2$ and two distinct CX layers, using [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate")s and phase gates ([`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate"), [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate") or [`ZGate`](qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate")). **Parameters** @@ -597,7 +621,7 @@ python_api_name: qiskit.synthesis ### synth\_circuit\_from\_stabilizers - + Synthesis of a circuit that generates a state stabilized by the stabilizers using Gaussian elimination with Clifford gates. If the stabilizers are underconstrained, and `allow_underconstrained` is `True`, the circuit will output one of the states stabilized by the stabilizers. Based on stim implementation. **Parameters** @@ -633,7 +657,7 @@ python_api_name: qiskit.synthesis ### generate\_basic\_approximations - + Generates a list of `GateSequence`s with the gates in `basis_gates`. **Parameters** @@ -659,7 +683,7 @@ python_api_name: qiskit.synthesis ### synth\_qft\_line - + Synthesis of a QFT circuit for a linear nearest neighbor connectivity. Based on Fig 2.b in Fowler et al. \[1]. Note that this method *reverts* the order of qubits in the circuit, compared to the original [`QFT`](qiskit.circuit.library.QFT "qiskit.circuit.library.QFT") code. Hence, the default value of the `do_swaps` parameter is `True` since it produces a circuit with fewer CX gates. @@ -689,7 +713,7 @@ Decomposition of general $2^n \times 2^n$ unitary matrices for any number of qub ### qs\_decomposition - + Decomposes a unitary matrix into one and two qubit gates using Quantum Shannon Decomposition, This decomposition is described in Shende et al. \[1]. @@ -741,11 +765,7 @@ $$ 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`](qiskit.synthesis.unitary.aqc#module-qiskit.synthesis.unitary.aqc "qiskit.synthesis.unitary.aqc") | Approximate Quantum Compiler (qiskit.synthesis.unitary.aqc) | +The Approximate Quantum Compiler is available as the module [`qiskit.synthesis.unitary.aqc`](qiskit.synthesis.unitary.aqc#module-qiskit.synthesis.unitary.aqc "qiskit.synthesis.unitary.aqc"). ## One-Qubit Synthesis @@ -755,11 +775,11 @@ The Approximate Quantum Compiler is available here: ## 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$). | -| [`TwoQubitWeylDecomposition`](qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.TwoQubitWeylDecomposition")(unitary\_matrix, \*) | Two-qubit Weyl decomposition. | +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`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$). | +| [`TwoQubitWeylDecomposition`](qiskit.synthesis.TwoQubitWeylDecomposition "qiskit.synthesis.TwoQubitWeylDecomposition")(unitary\_matrix\[, ...]) | Two-qubit Weyl decomposition. | ### two\_qubit\_cnot\_decompose diff --git a/docs/api/qiskit/transpiler.mdx b/docs/api/qiskit/transpiler.mdx index 1a8fe5a044b..853d1dae438 100644 --- a/docs/api/qiskit/transpiler.mdx +++ b/docs/api/qiskit/transpiler.mdx @@ -242,7 +242,7 @@ Instructions: 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. +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`](circuit#qiskit.circuit.Measure "qiskit.circuit.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. @@ -742,7 +742,7 @@ circ.draw(output='mpl') ![../\_images/transpiler-16.png](/images/api/qiskit/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: +You can see here that the transpiler inserted [`Delay`](circuit#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/transpiler-17.png) @@ -789,7 +789,7 @@ 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 [`circuit.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. +However, the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") representation is not accurate enough to represent this model. In the circuit representation, the corresponding [`circuit.Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit") is occupied by the stimulus microwave signal during the first half of the interval, and the [`Clbit`](circuit#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: @@ -803,7 +803,7 @@ 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: +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`](circuit#qiskit.circuit.Measure "qiskit.circuit.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 ┌────────────────┐ ┌───┐ @@ -914,11 +914,11 @@ See [https://arxiv.org/abs/2102.01682](https://arxiv.org/abs/2102.01682) for mor ### 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. | +| | | +| ------------------------------------------------------------------------------------------------------------------------ | --------------------------------------------------------- | +| [`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 for the output circuit from transpiler. | ### Scheduling @@ -937,7 +937,7 @@ See [https://arxiv.org/abs/2102.01682](https://arxiv.org/abs/2102.01682) for mor #### TranspilerError - + Exceptions raised during transpilation. Set the error message. @@ -945,7 +945,7 @@ See [https://arxiv.org/abs/2102.01682](https://arxiv.org/abs/2102.01682) for mor #### TranspilerAccessError - + DEPRECATED: Exception of access error in the transpiler passes. Set the error message. @@ -953,7 +953,7 @@ See [https://arxiv.org/abs/2102.01682](https://arxiv.org/abs/2102.01682) for mor #### CouplingError - + Base class for errors raised by the coupling graph object. Set the error message. @@ -961,7 +961,7 @@ See [https://arxiv.org/abs/2102.01682](https://arxiv.org/abs/2102.01682) for mor #### LayoutError - + Errors raised by the layout object. Set the error message. @@ -969,7 +969,7 @@ See [https://arxiv.org/abs/2102.01682](https://arxiv.org/abs/2102.01682) for mor #### CircuitTooWideForTarget - + Error raised if the circuit is too wide for the target. Set the error message. @@ -977,7 +977,7 @@ See [https://arxiv.org/abs/2102.01682](https://arxiv.org/abs/2102.01682) for mor #### InvalidLayoutError - + Error raised when a user provided layout is invalid. Set the error message. diff --git a/docs/api/qiskit/transpiler_passes.mdx b/docs/api/qiskit/transpiler_passes.mdx index d12cf8b759c..6b3d78bee8d 100644 --- a/docs/api/qiskit/transpiler_passes.mdx +++ b/docs/api/qiskit/transpiler_passes.mdx @@ -43,6 +43,7 @@ python_api_name: qiskit.transpiler.passes | [`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. | +| [`StarPreRouting`](qiskit.transpiler.passes.StarPreRouting "qiskit.transpiler.passes.StarPreRouting")(\*args, \*\*kwargs) | Run star to linear pre-routing | ## Basis Change @@ -74,11 +75,13 @@ python_api_name: qiskit.transpiler.passes | [`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. | +| [`RemoveFinalReset`](qiskit.transpiler.passes.RemoveFinalReset "qiskit.transpiler.passes.RemoveFinalReset")(\*args, \*\*kwargs) | Remove reset when it is the final instruction on a qubit wire. | | [`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. | +| [`ElidePermutations`](qiskit.transpiler.passes.ElidePermutations "qiskit.transpiler.passes.ElidePermutations")(\*args, \*\*kwargs) | Remove permutation operations from a pre-layout circuit | | [`NormalizeRXAngle`](qiskit.transpiler.passes.NormalizeRXAngle "qiskit.transpiler.passes.NormalizeRXAngle")(\*args, \*\*kwargs) | Normalize theta parameter of RXGate instruction. | | [`OptimizeAnnotated`](qiskit.transpiler.passes.OptimizeAnnotated "qiskit.transpiler.passes.OptimizeAnnotated")(\*args, \*\*kwargs) | Optimization pass on circuits with annotated operations. | @@ -93,7 +96,7 @@ python_api_name: qiskit.transpiler.passes ### rzx\_templates - + Convenience function to get the cost\_dict and templates for template matching. **Parameters** @@ -148,10 +151,12 @@ The synthesis transpiler plugin documentation can be found in the [`qiskit.trans | [`UnitarySynthesis`](qiskit.transpiler.passes.UnitarySynthesis "qiskit.transpiler.passes.UnitarySynthesis")(\*args, \*\*kwargs) | Synthesize gates according to their basis gates. | | [`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. | -| [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.HLSConfig")(\[use\_default\_on\_unspecified]) | The high-level-synthesis config allows to specify a list of "methods" used by [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis") transformation pass to synthesize different types of higher-level objects. | +| [`HLSConfig`](qiskit.transpiler.passes.HLSConfig "qiskit.transpiler.passes.HLSConfig")(\[use\_default\_on\_unspecified, ...]) | The high-level-synthesis config allows to specify a list of "methods" used by [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis") transformation pass to synthesize different types of higher-level objects. | | [`SolovayKitaev`](qiskit.transpiler.passes.SolovayKitaev "qiskit.transpiler.passes.SolovayKitaev")(\*args, \*\*kwargs) | Approximately decompose 1q gates to a discrete basis using the Solovay-Kitaev algorithm. | -## Post Layout (Post transpile qubit selection) +## Post Layout + +These are post qubit selection. | | | | ---------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------- | diff --git a/docs/api/qiskit/transpiler_plugins.mdx b/docs/api/qiskit/transpiler_plugins.mdx index e8754036d13..2e6d9df068f 100644 --- a/docs/api/qiskit/transpiler_plugins.mdx +++ b/docs/api/qiskit/transpiler_plugins.mdx @@ -30,14 +30,14 @@ For details on how to instead write plugins for transpiler synthesis methods, se 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`, `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` | 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. | +| 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`, `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` | 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). The output of this stage is also expected to have the `final_layout` property set field set with a [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") object that maps the [`Qubit`](circuit#qiskit.circuit.Qubit "qiskit.circuit.Qubit") to the output final position of that qubit in the circuit. If there is an existing `final_layout` entry in the property set (such as might be set by an optimization pass that introduces a permutation) it is expected that the final layout will be the composition of the two layouts (this can be computed using [`DAGCircuit.compose()`](qiskit.dagcircuit.DAGCircuit#compose "qiskit.dagcircuit.DAGCircuit.compose"), for example: `second_final_layout.compose(first_final_layout, dag.qubits)`). | +| `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`](circuit#qiskit.circuit.Delay "qiskit.circuit.Delay") instructions. | ## Writing Plugins @@ -97,7 +97,7 @@ There isn’t a limit to the number of plugins a single package can include as l ### list\_stage\_plugins - + Get a list of installed plugins for a stage. **Parameters** @@ -119,7 +119,7 @@ There isn’t a limit to the number of plugins a single package can include as l ### passmanager\_stage\_plugins - + 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: diff --git a/docs/api/qiskit/transpiler_preset.mdx b/docs/api/qiskit/transpiler_preset.mdx index d8a82d9901b..0993d07eabb 100644 --- a/docs/api/qiskit/transpiler_preset.mdx +++ b/docs/api/qiskit/transpiler_preset.mdx @@ -26,7 +26,7 @@ This module contains functions for generating the preset pass managers for the t ### generate\_preset\_pass\_manager - + 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 @@ -56,7 +56,7 @@ This module contains functions for generating the preset pass managers for the t * **timing\_constraints** (*TimingConstraints*) – Hardware time alignment restrictions. - * **initial\_layout** ([*Layout*](qiskit.transpiler.Layout "qiskit.transpiler.Layout")) – Initial position of virtual qubits on physical qubits. + * **initial\_layout** ([*Layout*](qiskit.transpiler.Layout "qiskit.transpiler.Layout") *| List\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – 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'`, and `'sabre'`, representing [`TrivialLayout`](qiskit.transpiler.passes.TrivialLayout "qiskit.transpiler.passes.TrivialLayout"), [`DenseLayout`](qiskit.transpiler.passes.DenseLayout "qiskit.transpiler.passes.DenseLayout") and [`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. @@ -97,7 +97,7 @@ This module contains functions for generating the preset pass managers for the t ### level\_0\_pass\_manager - + 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. @@ -123,7 +123,7 @@ This module contains functions for generating the preset pass managers for the t ### level\_1\_pass\_manager - + 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. @@ -147,7 +147,7 @@ This module contains functions for generating the preset pass managers for the t ### level\_2\_pass\_manager - + 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. @@ -173,7 +173,7 @@ This module contains functions for generating the preset pass managers for the t ### level\_3\_pass\_manager - + 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. @@ -203,7 +203,7 @@ This module contains functions for generating the preset pass managers for the t ### generate\_control\_flow\_options\_check - + 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** @@ -217,13 +217,13 @@ This module contains functions for generating the preset pass managers for the t ### generate\_error\_on\_control\_flow - + Get a pass manager that always raises an error if control flow is present in a given circuit. ### generate\_unroll\_3q - + Generate an unroll >3q [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") **Parameters** @@ -246,7 +246,7 @@ This module contains functions for generating the preset pass managers for the t ### generate\_embed\_passmanager - + 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 @@ -268,7 +268,7 @@ This module contains functions for generating the preset pass managers for the t ### generate\_routing\_passmanager - + Generate a routing [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") **Parameters** @@ -294,7 +294,7 @@ This module contains functions for generating the preset pass managers for the t ### generate\_pre\_op\_passmanager - + 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 @@ -316,7 +316,7 @@ This module contains functions for generating the preset pass managers for the t ### generate\_translation\_passmanager - + Generate a basis translation [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") **Parameters** @@ -346,7 +346,7 @@ This module contains functions for generating the preset pass managers for the t ### generate\_scheduling - + Generate a post optimization scheduling [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") **Parameters** diff --git a/docs/api/qiskit/utils.mdx b/docs/api/qiskit/utils.mdx index 1df583b4865..364a45a0f1b 100644 --- a/docs/api/qiskit/utils.mdx +++ b/docs/api/qiskit/utils.mdx @@ -22,7 +22,7 @@ python_api_name: qiskit.utils ### add\_deprecation\_to\_docstring - + Dynamically insert the deprecation message into `func`’s docstring. **Parameters** @@ -35,7 +35,7 @@ python_api_name: qiskit.utils ### deprecate\_arg - + 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. @@ -63,7 +63,7 @@ python_api_name: qiskit.utils ### deprecate\_arguments - + Deprecated. Instead, use @deprecate\_arg. **Parameters** @@ -83,7 +83,7 @@ python_api_name: qiskit.utils ### deprecate\_func - + Decorator to indicate a function has been deprecated. It should be placed beneath other decorators like @staticmethod and property decorators. @@ -110,7 +110,7 @@ python_api_name: qiskit.utils ### deprecate\_function - + Deprecated. Instead, use @deprecate\_func. **Parameters** @@ -133,7 +133,7 @@ python_api_name: qiskit.utils ### apply\_prefix - + Given a SI unit prefix and value, apply the prefix to convert to standard SI unit. **Parameters** @@ -164,7 +164,7 @@ python_api_name: qiskit.utils ### detach\_prefix - + 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). @@ -208,7 +208,7 @@ python_api_name: qiskit.utils ### wrap\_method - + 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. @@ -231,7 +231,7 @@ python_api_name: qiskit.utils ### local\_hardware\_info - + 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. @@ -247,22 +247,22 @@ python_api_name: qiskit.utils ### is\_main\_process - + Checks whether the current process is the main one -A helper function for calling a custom function with python [`ProcessPoolExecutor`](https://docs.python.org/3/library/concurrent.futures.html#concurrent.futures.ProcessPoolExecutor "(in Python v3.12)"). Tasks can be executed in parallel using this function. +A helper function for calling a custom function with Python [`ProcessPoolExecutor`](https://docs.python.org/3/library/concurrent.futures.html#concurrent.futures.ProcessPoolExecutor "(in Python v3.12)"). Tasks can be executed in parallel using this function. ### parallel\_map - + 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. + This will parallelise the results if the number of `values` is greater than one, and the current system configuration permits parallelization. **Parameters** @@ -274,11 +274,7 @@ A helper function for calling a custom function with python [`ProcessPoolExecuto **Returns** - **The result list contains the value of** - - **`task(value, *task_args, **task_kwargs)` for** - - each value in `values`. + The result list contains the value of `task(value, *task_args, **task_kwargs)` for each value in `values`. **Return type** @@ -365,7 +361,7 @@ from qiskit.utils import LazyImportTester #### LazyDependencyManager - + 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. @@ -405,7 +401,7 @@ from qiskit.utils import LazyImportTester ##### \_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** @@ -421,7 +417,7 @@ from qiskit.utils import LazyImportTester ##### require\_in\_call - + Create a decorator for callables that requires that the dependency is available when the decorated function or method is called. **Parameters** @@ -439,7 +435,7 @@ from qiskit.utils import LazyImportTester ##### require\_in\_instance - + 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** @@ -457,7 +453,7 @@ from qiskit.utils import LazyImportTester ##### require\_now - + Eagerly attempt to import the dependencies in this object, and raise an exception if they cannot be imported. **Parameters** @@ -472,7 +468,7 @@ from qiskit.utils import LazyImportTester #### LazyImportTester - + 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** @@ -486,7 +482,7 @@ from qiskit.utils import LazyImportTester #### LazySubprocessTester - + 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** diff --git a/docs/api/qiskit/visualization.mdx b/docs/api/qiskit/visualization.mdx index 9d872bc86c6..6911e6ce112 100644 --- a/docs/api/qiskit/visualization.mdx +++ b/docs/api/qiskit/visualization.mdx @@ -225,7 +225,7 @@ You can find code examples for each visualization functions on the individual fu ### VisualizationError - + For visualization specific errors. Set the error message. diff --git a/docs/build/bit-ordering.mdx b/docs/build/bit-ordering.mdx index a355e37ecc4..331f8a3e5b0 100644 --- a/docs/build/bit-ordering.mdx +++ b/docs/build/bit-ordering.mdx @@ -199,5 +199,5 @@ Note that in this new circuit, the X-gate acts on qubit $1$. - See an example of using circuits in the [Grover's Algorithm](https://learning.quantum.ibm.com/tutorial/grovers-algorithm) tutorial. - - Explore the [QuantumCircuit API](/api/qiskit/qiskit.circuit.QuantumCircuit#quantumcircuit) reference. + - Explore the [QuantumCircuit API](/api/qiskit/qiskit.circuit.QuantumCircuit#quantumcircuit-class) reference. \ No newline at end of file diff --git a/docs/run/native-gates.mdx b/docs/run/native-gates.mdx index 94a21adb656..580ebce3ea8 100644 --- a/docs/run/native-gates.mdx +++ b/docs/run/native-gates.mdx @@ -53,12 +53,12 @@ Select any system on the [Compute resources](https://quantum.ibm.com/services/re | [SX](/api/qiskit/qiskit.circuit.library.SXGate) |single-qubit gate | | [X](/api/qiskit/qiskit.circuit.library.XGate) | single-qubit gate | | [ID](/api/qiskit/qiskit.circuit.library.IGate) | single-qubit gate wait cycle | -| [reset](/api/qiskit/qiskit.circuit.library.Reset) | single-qubit gate, non-unitary; not the same as the initialization done at the start of a circuit to prepare the all 0's state | +| [reset](/api/qiskit/circuit#qiskit.circuit.Reset) | single-qubit gate, non-unitary; not the same as the initialization done at the start of a circuit to prepare the all 0's state | | [if_else](/api/qiskit/qiskit.circuit.IfElseOp) | control flow for classical feedforward | | [for_loop](/api/qiskit/qiskit.circuit.ForLoopOp) | control flow for classical feedforward | | [switch_case](/api/qiskit/qiskit.circuit.SwitchCaseOp) | control flow for classical feedforward | -| [measure](/api/qiskit/qiskit.circuit.library.Measure) | | -| [delay](/api/qiskit/qiskit.circuit.Delay) | | +| [measure](/api/qiskit/circuit#qiskit.circuit.Measure) | | +| [delay](/api/qiskit/circuit#qiskit.circuit.Delay) | | ### Eagle @@ -69,12 +69,12 @@ Select any system on the [Compute resources](https://quantum.ibm.com/services/re | [SX](/api/qiskit/qiskit.circuit.library.SXGate) |single-qubit gate | | [X](/api/qiskit/qiskit.circuit.library.XGate) | single-qubit gate | | [ID](/api/qiskit/qiskit.circuit.library.IGate) | single-qubit gate wait cycle | -| [reset](/api/qiskit/qiskit.circuit.library.Reset) | single-qubit gate, non-unitary; not the same as the initialization done at the start of a circuit to prepare the all 0's state | +| [reset](/api/qiskit/circuit#qiskit.circuit.Reset) | single-qubit gate, non-unitary; not the same as the initialization done at the start of a circuit to prepare the all 0's state | | [if_else](/api/qiskit/qiskit.circuit.IfElseOp) | control flow for classical feedforward | | [for_loop](/api/qiskit/qiskit.circuit.ForLoopOp) | control flow for classical feedforward | | [switch_case](/api/qiskit/qiskit.circuit.SwitchCaseOp) | control flow for classical feedforward | -| [measure](/api/qiskit/qiskit.circuit.library.Measure) | | -| [delay](/api/qiskit/qiskit.circuit.Delay) | | +| [measure](/api/qiskit/circuit#qiskit.circuit.Measure) | | +| [delay](/api/qiskit/circuit#qiskit.circuit.Delay) | | ### Falcon @@ -83,17 +83,17 @@ Select any system on the [Compute resources](https://quantum.ibm.com/services/re | [CX](/api/qiskit/qiskit.circuit.library.CXGate) | two-qubit gate | | [RZ](/api/qiskit/qiskit.circuit.library.RZGate) | single-qubit gate | | [ID](/api/qiskit/qiskit.circuit.library.IGate) | single-qubit gate wait cycle | -| [reset](/api/qiskit/qiskit.circuit.library.Reset) | single-qubit gate, non-unitary; not the same as the initialization done at the start of a circuit to prepare the all 0's state | +| [reset](/api/qiskit/circuit#qiskit.circuit.Reset) | single-qubit gate, non-unitary; not the same as the initialization done at the start of a circuit to prepare the all 0's state | | [if_else](/api/qiskit/qiskit.circuit.IfElseOp) | control flow for classical feedforward | | [for_loop](/api/qiskit/qiskit.circuit.ForLoopOp) | control flow for classical feedforward | | [switch_case](/api/qiskit/qiskit.circuit.SwitchCaseOp) | control flow for classical feedforward | -| [measure](/api/qiskit/qiskit.circuit.library.Measure) | | -| [delay](/api/qiskit/qiskit.circuit.Delay) | | +| [measure](/api/qiskit/circuit#qiskit.circuit.Measure) | | +| [delay](/api/qiskit/circuit#qiskit.circuit.Delay) | | -The `init_qubits` flag, set as a [primitive execution option,](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.ExecutionOptions) controls whether qubits are reset to the zero state at the start of each circuit. Its default value is `True`, indicating that the qubits should be reset. If `False`, the qubits will begin in the final state from the previous shot, and you must manually insert [resets](/api/qiskit/qiskit.circuit.library.Reset) if you want to reset them to the zero state. If a job consists of multiple circuits, then the shots are executed in a "round-robin" fashion. That is, each circuit will be executed in sequence to obtain one shot from each circuit. This process is then repeated until the requested number of shots has been obtained from all circuits. +The `init_qubits` flag, set as a [primitive execution option,](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.ExecutionOptions) controls whether qubits are reset to the zero state at the start of each circuit. Its default value is `True`, indicating that the qubits should be reset. If `False`, the qubits will begin in the final state from the previous shot, and you must manually insert [resets](/api/qiskit/circuit#qiskit.circuit.Reset) if you want to reset them to the zero state. If a job consists of multiple circuits, then the shots are executed in a "round-robin" fashion. That is, each circuit will be executed in sequence to obtain one shot from each circuit. This process is then repeated until the requested number of shots has been obtained from all circuits. ## Next steps diff --git a/docs/start/hello-world.ipynb b/docs/start/hello-world.ipynb index 6a6adaf016f..2f33b38992e 100644 --- a/docs/start/hello-world.ipynb +++ b/docs/start/hello-world.ipynb @@ -54,7 +54,7 @@ "source": [ "### Step 1. Map the problem to a quantum-native format\n", "\n", - "In a quantum program, *quantum circuits* are the native format in which to represent quantum instructions, and *operators* represent the observables to be measured. When creating a circuit, you'll usually create a new [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit#quantumcircuit) object, then add instructions to it in sequence." + "In a quantum program, *quantum circuits* are the native format in which to represent quantum instructions, and *operators* represent the observables to be measured. When creating a circuit, you'll usually create a new [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit#quantumcircuit-class) object, then add instructions to it in sequence." ] }, { @@ -119,7 +119,7 @@ "raw_mimetype": "text/restructuredtext" }, "source": [ - "See [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit#quantumcircuit) in the documentation for all available operations." + "See [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit#quantumcircuit-class) in the documentation for all available operations." ] }, { diff --git a/docs/support.mdx b/docs/support.mdx index 20cf0f0906f..cd1bf45c7ec 100644 --- a/docs/support.mdx +++ b/docs/support.mdx @@ -87,7 +87,7 @@ An example of citing IBM Quantum Composer: The `save_*` instructions are part of Qiskit Aer project, a high performance simulator for quantum circuits. These instructions do not exist outside of Qiskit Aer and are added dynamically to the -[QuantumCircuit](/api/qiskit/qiskit.circuit.QuantumCircuit#quantumcircuit) class by Qiskit Aer on import. If you would like to +[QuantumCircuit](/api/qiskit/qiskit.circuit.QuantumCircuit#quantumcircuit-class) class by Qiskit Aer on import. If you would like to use these instructions you must first ensure that you have imported `qiskit_aer` in your program before trying to call these methods. You can refer to [qiskit_aer.library](https://qiskit.org/ecosystem/aer/apidocs/aer_library.html) for the details of these custom diff --git a/docs/verify/stabilizer-circuit-simulation.ipynb b/docs/verify/stabilizer-circuit-simulation.ipynb index b143ba47f49..2ff2cef98d7 100644 --- a/docs/verify/stabilizer-circuit-simulation.ipynb +++ b/docs/verify/stabilizer-circuit-simulation.ipynb @@ -14,7 +14,7 @@ "- [CX](../api/qiskit/qiskit.circuit.library.CXGate)\n", "- [Hadamard](../api/qiskit/qiskit.circuit.library.HGate)\n", "- [S](../api/qiskit/qiskit.circuit.library.SGate)\n", - "- [Measurement](../api/qiskit/qiskit.circuit.library.Measure)\n", + "- [Measurement](../api/qiskit/circuit#qiskit.circuit.Measure)\n", "\n", "Note that using Hadamard and S, we can construct any Pauli rotation gate ([$R_x$](/api/qiskit/qiskit.circuit.library.RXGate), [$R_y$](/api/qiskit/qiskit.circuit.library.RYGate), and [$R_z$](/api/qiskit/qiskit.circuit.library.RZGate)) that has an angle contained in the set $\\{0, \\frac{\\pi}{2}, \\pi, \\frac{3\\pi}{2}\\}$ (up to global phase), so we can include these gates in the definition as well.\n", "\n", diff --git a/public/api/qiskit/1.0/objects.inv b/public/api/qiskit/1.0/objects.inv new file mode 100644 index 0000000000000000000000000000000000000000..53aa0795e9da5384cf64bccdd569f9d0ef4c5f65 GIT binary patch literal 68345 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 zls�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 @={qzUda_VYrKB}o@eijW4mG4pKH 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 literal 70005 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 G2PjK>wfUa_ diff --git a/public/api/qiskit/objects.inv b/public/api/qiskit/objects.inv index 53aa0795e9da5384cf64bccdd569f9d0ef4c5f65..0423da6ec5092c2b57cf1345ec52ab5fc23e5a75 100644 GIT binary patch literal 72332 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 literal 68345 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 zls�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 DTtW7CFc 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 H)4;z0^Xc2U literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit/1.0/circuit-2.png b/public/images/api/qiskit/1.0/circuit-2.png new file mode 100644 index 0000000000000000000000000000000000000000..a00f5f4fa90b359d4d4381ceb6a030c2b9321130 GIT binary patch literal 3876 zcmd54J*%P&Ejlh=p*e5(yxJ3Mx_#V5AG7hbkS#gCL;^NI3#V4u($X zc%&m8gakq&-6*|=&K>@I|GxX@{<-r!Yxc~nJ$voF*Sp?#Cgz?Inv+eC4FCX6eLd6z zu$=`h=L{4)uUi&&f(_F9wwbpH*4`Uu>uCqvwe@y?j`e=-^i<5(&eO{Y>!vKPB7aRz z%+cH1-Ah$L!S(+-$YVVn6kyVlKHwm%?s`wW0D!~j*jPevv62A5m7tH(HuZbINDI7| zh-++L)7D0#iLmp@m2C3sJWV>0D44zp$Y}1OkDOL@_Pfb1dxq9MA=NgU}vx8Es`H^6_p)^mUgJF00gQ&4F^YMEBbI=GDgM8kvU%#H=*rNn~@uTR!Hd2ii&HIk&(bQ?kxg=U@#b37>s0ic=)9?@mSVe z;kNucsVnrrW!vGuAHwD3Z~Ot{S=w3SN+Iz&* z+_vx*zHu^&VpBGmsUFA&3t9P>x>N`4TpgoQ zJ(k9i?=?e23knMK3=L6kZt~{l<~jG^Z`0EJjZd*s{F8nJGevxt#$#T;X4At*=H*E( zP^-9YZEf}R^|kNc=g~Oa#(>X>7FFq=GZGTQy1Na9HG<5l;mf!2Qh$Ndm6nzU+!~zJ z5D3ngm>72)4(6R17RF*(?atEL+WM)uxV;q9e$U+e_2JExrLn)F^VzKQL}q5@tGGBQVEXv6&ZR_g4GsFU;Kz?2qtNKw+S)Pb zkg-N~&{~XAhyVJVxTGY6PN(Cn(DJF08XBTXN=hmL8*rm6wHPp5$Fr;T8-sV4&)$Y+ z>W+?$z24aHZfR-B`TUuKE$RfYLczofSf`H1Jt!P*B9kx5%gftSSvfdb(v%(g$>h@x z4nJ8lLdtdy_m)>j9kN*fJRV=-G2O<~V1&hD+jrJ~zDebTLXJVv(b3_N?IS_4OTsp6 z^0|#yhv~fJ5{NhnC@3g^5hpf&4Yk2H0}gVuPgG?gunHLcBoNGw&dz0iy#VaR@Asc4xnv0PGtgem6pdRWKYnO3HUk<&L71NgP`bKtDjomg{tZ9Rrnb?q1DBO; zjyZSvEDRQ3Qc|Mr;KV;Uy~<=}mq=Fo3fO_Eo;`}_M7%gfxry(`I%PEG>e zHCb7r(^pf#=z;^S;C7YVNre>F~^#!tNyxvJ1-Q<}i=++ahU+kP3z^Iw6ZBen@ zyOgf3E{}s8d$b8H_TID7VND2a4qV{0oNQ9R%{F+VRm zQ&iYAz*A0B>pnae^VQ~`i`GFbfLX1#%tzyFx7FH+Qv#x*Txc{pk3fJ_S6YlyD2~aa z#LlHG8SD|Q3q;cb36JNksHk{{61aHrWuNAe@Xy{%Wn>h}*qFQVV9P?zvbuk2Z;Q!% zX-*{h?G%jqhXMo$D?58c?Ftq%))vKnv7bhB^|W$zMWkn7)f=Vnq?pwc{|c{nT^g@h zVKUJsCg*zJBO`_jA7^}q@$udGkPQK*vxZP5b?}Jr@CgRv)wgd3iSyu5>c4IeD8^h> zR~MlI0>TgIIy#eOAl#s=Gs;}=C1F>{PJ?;8_y}BAlk&QU%wzDBXh5C zSjBzfIOpJY8-9p={kjPxh7yN9(a+|UY}}grC95LpV4>~{&GLUA9%cb<>F6NL>3A`0 zT|*C*>7h_s2WQF2$pMUvjNmdd+W!7XUS3}J1&Y!$JG;qm$+GsRL)X^Vm0U*T>W>ch zR6M3m1_cKnuM_mM?(o$`aJO*#Tl|o8x#W(o+gq&qF)=k2USLAts$0+tKMBBKFclR~0-yxtZgO5*G7Gd62W+MlolToB@P7X;k$#x&NFU2okfYC^tOc zD4rSVYeJ4WqT|j3B?qGxu*ACcvQz>k>WCG8eKu3WWke0`hUk$h4s< zC^=@0LC7Qn>ABua+3u>sgOJzbWB5(wv6)bg7J65)*YUY6v(-LZ`9rRrCC8n&;3*(yz4eZ4h+$}uQW5; z{`m3_pA1moK{-{d0r9}zIb;=Ip0^ zH1}5^5)u-+>V!%~gRl)IGnYU(4UPCZbF_Hh)DJHD>b>%Urv_bAPv3yw7s<`deXL8P zqoa&pzqD;_#l2NU_z>pTxQ5~sbYr2&>0)vQtD)rBsbU#Q` zR8+rnW;P~q8Cx6lu|g{#K((yA zJRvD5vLTT9bl}5nzk^M3LPCPlUtY&=n6{GpaZE$T!PsE%SC(xr%cRjw<&Va#c+I}@ zuc(ps+~Q^x|1~KC1A~<&c7=&d9GwMtK3>fO>Zl)+hFkq^Vm$fvG^}D*7%w%s{nJABYRxVmzR8Amte1Iq9Ne#az8ZBgOFXDS(I7%kJtglxCg<7Y; zw5h9$y|lEHQtlA%k(P_b2B&q85H0SGGz9OgOg5jpI-eZC`TKg$t2b=z=M~~vYmD!! zbk3TUdnyTs97PjnT2!|0u9vQwj$o>aW%hP=-@bnjav7VP1*v;`i{NwH9?e+F>NWiQ4SiLVd^4 zYgrws>T^!?pifFgMa7U2TvsRi<_K<<0nQ z!^5+^J73&G;sG@m4Cq*CUQUI2{Up~8G}uXe@$GZNS;q?_!(~i9+JKs4Uq#!wofpvX zqN91PsHmua9(~x2_P*&Gn1jxLAg-z!Krwy>PyQyZNe9^olK;SIHTX(W5oLoC^5&W0 zC!vhhFLu`APkj~nE~_bi@NwFQC!NFD^tk0#m}+SO*93cVs+_I~f=f29C%Of5Z}Ex3 zhJ{m$zfZ3v@7^cg!BicLR=UqE75aeqnj~bu5Zux!^6>EJcf1B_#3gd!uroOSmbNx? zFT*k&-#x<`H=1hw+Beyb&Q5J#Us9(lUP>T-Nqv`*tKvCx2ITxVA%v5m`};xDzH+lm zMJ-znWb+ES`0CfKG}>CK492bsZ4D->q(D~+BBHQRR^F;MGCSl@z|PLD z%?{>2!;_SfGSzuG8+Gf}iN@XEvchV9XXnYqXj|LA9?qEzU!R!xVJvYNAM(%Nv+P7q zm=wG-&IgCPgG3@9piq%BQ&STD{{H$Pwg%}9fjudKi3mN&lY^o zBqju(-E5lm;Bwzp8SeVj;iapGnX?t7Y3Ax^=iqAh+We-wm9xuh2YV5iButd=rnRf9 zql=V)0P;T;z#N=k39#ShbOT1NIX>2Rfgm!izi&K0k4R1kqJ5^SB>&7abz|B~=h>?| z!tH$egS4<(e+?zwFp_LtrR+??Un9M4*)Mo(^0FB^B#&Q3eiYu6coZ*P6M4gYWQZ{` zC)qhN*%J{!sQWX5L|4h+I(b02g5?a;ip!;=(zOW9Vb{a)2Ti<%nFAitTRXYzS{b`( z_Q_nTH^Ra?KXpYRASx;hL+i(|#}Jt<2M3;D@!PPg-^;llBM?ly#L+F3bH{g@tO`w5$DCEL$1oz#y?&$oCgz=e^>ePn8k#8-K#K zs++L6$fTzZ8dR;5y{eRKR|tatWn|Ti`T6tb1qFgp{_BMeEhJN&_e9(oy)CpbLdp-w z6_mK35HYGah+#}g>53_wn(CUrndX1K>6Y2p$oBsI`*v91q>hQnOwN+qZXN^vWP_K; z(D1O+VmIy7Hy0vfW8D2Qz5V_B z8+;+>g~y)W-qi**z^-A9y|R_nZM`yMaupR7PTZU0A+Xzhg9+@mpJ|Mmn==;`6KftC zdQyb-Ir#PJj)1_H5XKD7{4ri$*~P`Z6N^bzAt8h;a%h%(tuzHyRn-&= z5>is9ojGL|Nk^!$u`x*;$#exDAMXL_T5&O7r=@VgGu}u>k@nbn(`qIrCdauS*HRyN zfn&&6rD%rpG+PUFb0Dy|w^su!o~m`imzS3hnIgzBg){3I8?zBoun*XXg%|k8=t}gS+)-mg1j{jVSc_ zNpnlfmC@1B&VhkYwcM6KBFfmbv?v_TE|Oi2&1I=q-p9wsMMuE6Vd7K3iPG6KNofP~ zv$L(ikv$yuMbr7XQY7nUNL)pevL-Tz>Ykm6A%;=dlDGkb8Eo?NgTvvOd3kx?Bo4P` zfb{^iTm?r*!KL2hz_P}Z!utgl78WQa9egrd%->jz73&9n`o#74U65)#_bpjjHd$HO zu;}Ra=0GC6%=-nOPe0}5all{{nwpwAcWA=G!xcO|C8wsQCRqejZ-7uWo^DE8T3X(` zeVgF*>(|!cMX~ntr%vnU57LHnU14F$OQJD8wzpL#pYWlVDr7(W9+4?+pZO)*>6p|y z;z_&XtT#0+ExB4+TLJIr_wpgO^vhbko)0s=`LI4vKu4ePa`rPYmzCu+p z?nzin=;)ENo8Xvla&(VAGDA3Y zrq)u5sQ-u(@z|VVqaA@->(s*|B7{%}b|70hgoLQX#l<0iuid3Ti-{Sj93Y_{IXMY6 z9?g-00NhdxFOngieIx*rrg=g*} zhshGl+s1<`Wvnk2f1i+W6GZ79m)Z7gGrY=%)((lRGBzpE;}jFCQg#64O2x{Ge1}WwIWqhSO4O%g{5nrU04YE{{3O9tgpeA+4RIjSavo?Nk`MjM5aspz~z%GiI?a3 z(Y7^X6BGWS!3b3SSiXwhKs?tq6W@K>wY9a`wYBiYo zn4~8&ri34kd+p!X#g>0fQ2ZQgk?QBLFf)E0;HITT@jzyIr9t+my8|eVQezAW1h2H# z%}4F}=*Y>aAWTeRe*92kx$k^6o<}<*I9R#Jch$~;goI@F&!551Ze%6P4Iw`(Kmexd zJ<7bK26si7$c05jg5?Ozb978&(-eyYp1Q1!+=cuzGEDL>27Z&;K%TpO5?MNT05C;Y zR#w^<)Y&%3ux`usbeJzz_Z)d1KL6p%5Q)ZA$(f5Ku%nOgpxO2Hh&WCa8;mhZo;(Td zP)8b5?DhRQ$XQ$!9Z4QZp zbka36{C!qoP|}{Oo(Mr@O{M1@PuyrmpjjL)Qploxwk4SKv8JZ7qod=x@2V2}r10_d zZs#|{>D7H262=1u3gtEJm~x~a9r(r3jxwETzea50qmXX^kk9c%WBg!w9P<}VD2DqF z@-Uf%>8UTtNJtbwQ9OC_L=b&;q<1>>3%hbk>*!$$U+)|qrX~r#@@gO*x#NjO%YNWD zB+Nv?V7%|UwJ=7uItC4%v2X6Yr$eAWgJ}Qaxc<-X?%>GCRcQP0aNLGjfMhNI?EKv6 zPYc1q;$oG-OS8d!UtNQhu@tcg74z79&PQjP#8BpE)fPi`?pyOI65AJsWv0I`_|j|! zJsdW%n27dvo?&8@NQSIYabubh?c>u^P5_8C4m0*u8tkCslG(EA8yJ{hoE=ZpdkDPj zO?tDkVhx;YI$nx!^zi7wpbia!-4qnAfCs~Skc`RHEBf+!m>cp>Or&4xOL?_2eH}ae zd;fHAHD@&V9x{;0Q(U02vXW+TanaFvXk)5LmLO^+ijw}sV(cFgPaUJ-Gf#Uo!Nu9k z>!Y5Gj=5)RGL|zi5#zW^_vL<8=;0O?QziAH1gV2>osN92rx)_|tFWZB^m>W?)3)-> zfC0Hn7CJgQNstQtsrLh&=G*^t#&J%Ro8j9}*Nv{V%%{ts3|Qa#?G36x{%@&yK0bqQ zG5)$>MXkNAAcL!RjM#`3my`?^y(puP-q6s&_b)2Cm!Ni=kB?8s(9rgVneWadC;aLr z(&bm;Ou_b|1TX%Jkw(zN;f97aD8-@O5u2(pdGbme=sD!AAEjP8IK-q$dzdfxr}48j zq0gm4DA}<#6xL6kyu&M6XUxvY0oYbD3J+Gmla`h)+0v-2sp+^lKi$`{8lYiheB0Ui zxTL*%@t-BEwacsQv@}G_I(e(XKzDby4jf+K<{$g#&U>}9Rc${7cXx4M+aBkSHpPzma?|_eqzape|0cgJI0Oy_`FH^LzPNh1|tXOf1*u zjs_$r6(iyQijV&8>q{*zlXkr<=Q)43@3!@ixYVvH=K$bPchE)@kfWRX_xZ1Ckbg>1 zyjI41zAfv(?t$aTYZ=XW!nR!PgSNiKt`v2d%L=2x%B{2D$9RJn0=#;{S;W{+IOd zzrR_PtY7cWe|C0uGqJ~Mdsf~e(ZU@7OHf!C@xe+rGhgiYlzTVm9 zz%R((;(wXhL~c^9$BZvMJ`u$afu^$n&|oY8fhi~}lW^C+y1PXVxNgJ#n4#zS{vmm>L|U0v!8;T1vqbmDhGC6NeI@SJLp=DP|zey;5P` zlBwf*<_duNp@s&TxcyXEU7Zvc7guI>_LZ!xEbqeFWk*yOV_cSniKN!&XQuAGTnB_? zwiOlDgB%kR6SF`9B+2>7+S%E~rl#8AzD9C;jtG+dV{^GE0x1O(H200_7j3k4bZ|;Y z(1Qklv=FcDc(iQ>*VkXo8cOH6vrS8O5v3Ap!J*iZeW>1VfE<`YwU&$f7Z&msn>4Wv z=WB(`vO&D1!sbE(?wSZS%yr`=BM+O98nTVDOu&gI)c4;wMl=W}%{4-XGO z=5L6JiFI~&E9mINHmYqnr607n*KIsxT^MDbzhW}zjatGohg9JuBqW$l*SS4bR}XAz zl1osVM~s&g6gJC6-_H6}Ib|)z@UbFC21`u&dcQWRiWW_O|I0KZVV=g2b!>(Qwcm6N z{plgkY~oxteVJuIDhqBB7ghECHa7Aj@i%`!v{K2Y#jWqEnL2M^L47DSe4*DC1! zTHdeU_q6KlSy`O3tdt__n;B=8aQ15#8{JsyKr^#lQ6ZA%)XPl?B)W`7_~}Osy;JeL zASY-bJm%oGlvHSs5ivm4c}}Jj{qpLI!BDYX;ZfO5?#iNk@O6`;${?!5u!iI2O{luM z+R@p$1+eHZ79G(`LO_G{$s;vrpNkze75!S-!jd*(@got@@?Dm~4ZsKy$`E?!KXWs3 zdtco7d0LHC4_!mOB%QN$x$~mhUuhLe$=;6pRpGR?Y^3xkh?AecZ^FubGIIO6+05e6x1aDsI+shlS}noBqFE)^ng6Av~VCTfDliyBF8KvHL$?Mz4ZEOg6 z?^&nW2P229b)G-Zd5V!sZ3^f~mJkwg=J1h9s<7#|pTWe;zZ%}|FD`H&ut+J4+;a^I z*8CAh#TlEFL@XguL)SBqE)xOZWY5{9Ra*`rvbHLYn7Yf?@ec}{mYJJFOKHvdH}mx*br^HXNEA=4er|^a=n{))dQE}Tbqu?1GJl% znAqB-x6W<79DVM6=8nB_)G&0wV1pce_l?_cvaRwmA*r^k>4FIcgTX6aY8F{-5QxQ< zIy;;N4d$rSFpqqX|C|EFy2!LXd>)q-wlCH7V_|6tMCW_vmg6f6+o;@K?8=DLXqDU1 zZ#nI`+dL`_jMOBIp1}xFK;wJ5+qU=iaE?Zx;Q<64Y^rg|_tW+kW;Pu5OH>P~GPSW? zyPmjRqP0$!_+dUGDCdMfjI4dEpH0F68^oo$p(WAV(-Zh8M}AP?z0_s;o)W}P zNq<=!5Wp4QfiA*`#*4DK_9$jnY#b9kJrT4`Ivc8;#B6Me3(%H3r(yTm#sm61DvDX6 z8a_5S7<21Ypd(?}ac9@Jx3f<2E5B<50L}k1KR;}K{05&$&;k2^Y=2)_t()MM!+{W8 zKcSF|O%>DAJdNgWF3W;$YtKL`v`$Vk>Fev)dhK$9y(t}=6JPMHtgIk^a7eaE6WVh* z%>#liE-rv-|A<{L0`)kS<`;UZ4)b(qb~s)T!@qXzn&;_8&8@^9A(thMpy1%Fx;my% z3RVRJ1E!OMjfjN>OERV(UfnNMvSFV~O5TejC%KM~k5xepyo-;I7X^uT7X~YBlN1mT zxb`r`gp`hN<-=s-=`Cf0oi44r_YRlsf5|d-tPbbrcE$759I<}=@+FQAW^`v7gBqV$ z)Rp)XSH*}j(tESF{w?W&Y^=)YOE80rbZZ*v;)q)wur%#_|&yIJ2SRw%NLC&gumKG|0t6>B@prEK|W@h#V zXvxe^pRTHZ;A_rO4E+gYU3s}6$R$=lq7(tnL#EvccWa#&!{hGp_?pA1lWRL-*lUs$ zH)d!3#can+e^(>JqN3W0^(zGJCd%pNErl6Be*75uT-XgCG}5;&PEN1UMOUDL;^LtC zdg-P9vWoclMP-41qD+pt6)H-nd)7KII;FxV4jsucQki7zY#;2?7FAV;Kt~pwgrSR0O1#&_jsI2o?kd0ja?P zNbd8;}UjHf3$q(h~?WGPs20wcErvHao;An0=>MNv*f`7n}sXiOP!+~F_p#S~& zvmNyC{Z=^iaQ9nqE?~D#{wfY0j_-X3{X*ssV;jN4#e4tzYyW#n{`V?@9e9;Z6@8PP z$(5#=%0FX@TG!Gv1qCi?tr2Xxo{ z=eJwt=L@Nt%8o5D#zMh*Z?OY0T3QSK=+UDY3c))DAz1ZGBDA8z1#$f8lqlBShs@4u zL^T4Ns;LVK0M!ZnZPC7`wXmB;W;rIEwWI8!xvKG))@R z>{?@FLhXBrr7<3}HM;4cALE2K($gVUSgn~PNkJ$|j8<<>@T{^*gtxn>)afQ6IXCUC zhs*qUR^iLB(YtB_;KJFrQU?CVrIfyb!88+nZa+|U=}L>1Lm0@PiT+SX7){C0NAEW@ z(OY~!SI1hC{Df4td;Mc)r?U2nx*3ZY)L-l?T#wbmeN+^}gN%2_Z$*E*3!J}vRpmPm zeBX-hyfIoAl6=&)r|s%q!!-^Qw^ja(!dCdx_5?Fo2ltZ43Rwy&%C23lQ&gu1-~jwj zoPl3dEvlxcM9b>yoQm9RJuVm?9`5V!-)ESTnu=FFJ2zWE7*nGHB=5x^F0q z)oB}0OsCV2YG_o};0sfe0#meXQLLU0x0}-?yoB>vcK-bp=1w8^N>;|>W@1V05?Y9- z>l|v?%Qg{M=C<7Yd?RCH7jA2^#B=iNZ;g$OleJOK&9QRC;fBP-#0xkB{l+LshwAw{ zR#*ExftE4To0D@kR#tm$`Xy?>+QsSf`}>6rv`=p%Y>_mPDA_0aYb)OD#bWl<)Rc2O z&4GAns;Jd5RzLBY^hNYFjrF+aGh`Ph-|l?< z?ZX|)=i|&REDG`7ZBGv->!Vi=nf(kW@|VJR6k68`#T%!gg8`FC&p7 zdo>6H4YnT1xY%PpmGfxoN|c&;`PRJ93g#l{4MX37myHmUGzka@SO9Ot0#ACTDxZT3 z4~?@T+de~J!)F-`tM8=GMDKbcD!yYP*(Ia3sCJ=dl-J+ipVbgP@BVGw=zxPTu;*BQ ze+$u)G&@`OJc#y4C&)N*vsBz#KHR&UQAm2x)EUz2OUMebW(-_@_T_FbtJJZ9(q*v$ z)-6@|toZ_2-Y)a!<>`;|is}BB_Zz1?Ep=>h?s%q}TU<2AH*p9wQZF zGc&Uthp#+N^={C9dFD~uDM|gO^((_lBQ?s{YVXpf9a4J1KC;1|ZYNBQVukC_T^~5? znzQty!`KS8S2KB;{c#2#>3^*$n;>)K2!j9agp8dO4A#Bl!o$oLoj3$SLPA1H-MQls z1+nxbc7o3$k)}Vs?5#(0!r1u^ovn&E>dX#Q-SyQC?jxMG+E~V$^AB_vM{1o2GHX*W z91NZ^yfFLQ1>O>oNHKP&BBI2_V5MQC_a%C2O(+S2Rm6ZBT@$mmtYGc5*sQ?)yp#B> z8a3ri(&tt#>{P2HmUrl(DFj7+LvotNW4442aKvfC{!-AnMM?ZNUFC*iT*_x4&a4{gp1TXJ&&fb)6nQ)!-kvQ8k2AsD6hF@tfHWLCEbN8$Nd+c zJq8t@-lkOC@#L&*@?G(r&Vwb_CgG+124O<|94}m>fRLf2Vl~cg^9L6eh<&O1BPGPaDF?;l06zPe2W$G??c6`jC z#fhpYcRq;CRaS0Q#$ws6Ts>xp$$H(m1t#VC7< zR*Ot2Dm-NL`P!z;M_k*42Y&yscV48rPOUptf_`ebxh9?XDPd2@tehFGqQp@=!eq{j zwnlM#dor%zncKWrl1E?Om#ff6a%gFHA13V&Vb=?7$kb)?F8-*# zjP0(Fys@S_M#bcF(~d$q@FgMxgVU;?ZzXXySuxY z6@gEv^>+Rs5@U_CT3}9HPBsgAl@rDEWPFF`F4>=IpLavjQMtduSY2R zwn;Lgrpxhs*5ro9ePq3!6BeFz_l4`E!(q80kL2te7-xy$3aBaNnP)G~#qmE8<+|=9 zB^D99!~N!oYCLX}jMTBrqtmOXgZf7!O*CUj} z`nB59TvgZ6y6Aq7XAg_R)!J>Uj|^rJLyqB&Wouek&{xV_YbS_0)?Zvq=zK}CXCcyiUUw<&$5H|NL zeVB0IY6R3?vzuG`ip~{ZQr)3!^Hjl||C5$e+tUtk7bYCs8YLGV95)du?KSub4O*bn zmrrjC4FtDO#eR^*@VviZ;%?BC@g1bId#Z+4^u2hEXOPU&7TNX^iP!bWK9A(h^+yc- z-U!4LI$3SDq{uXi)@YtF7T%Z+vc;@cPYDl9g)hwp9=?~5$J>vt5G0Axsy?-Fn{x!UGU6LG&tNc^ zO%l7!7t{v7eJ6UT8Q>u^Br;u>S%*rP2c7K0Ob#yNm3tAPySzrndwPUGbt*ZT8zK_x zFkldH+^Xz3GeQD`3sAs{`P+k=pa5#NvihMDui{PGUKz%#19Fa{XrXTHci%0L&xbfj}pF=>1wfoJqS_QGR3cYV?rbf}A zB9W7KsB%}PmRiMgiaAwz3TWnlijc?4p%4#DPk7aps|o|&Mlke?@(xMWplHDTOyk<&21-o5*KB#2!QiaR2fYz&l@R{W-NM;aoV~wuOc*O@ zn0VxBM8OrgM@47B&69l0_j*kbGvlCH_5?s4?XNGrR0~;}NJB4FhkU-TI8f6)9+{V$ zJCr$QW8_{#XvI)Y8XI$#BsKCw0;*VVYHlNEhgNc;<(?IKqx-?u9Mj<( zzOeZDw$%^5BCN`G+4i&$qk;8?gZprTPovUD=L_~2aNpLW*0@;Yl&XbAYanI0t+i#d zsqrIrxo%qyqAJK_o$fFYa>2slG9iG(pDG1sUYRSM@SrEh6lWJYlLhXZwmYKYeymO{ zm%i7RLZ+Wbm4SOc3*1Q|4~7cP284%orN%2T)|zH1TXsF;$W^+FS%{|F#xC@84V6Z< zyoU&IMVWeAF^kGY1AfL{?VC7Hat$%hjXRx%OJh09+3OBsV<^gElEp|yI7Xy9oL_jp zDHY(+-Me>Nrv9naW2o$~b(w-u65Ke~ye)2@(b7_Ty8BqYQl#8tTggzyZchEu!nj}0 zr*z$_pW`Ml%t38(7_V^Xg?FsR0%GA_I%@oVBfvcYVpf~d$>=SVgG6o@rOb)gIZ!1W zBru=SkV`Qh120)b?@%xMc$#qfUNnZW#hpqF5O%6@dETVjE!M2?VG=#He&HdYRq}zY9k!+)I0l^Acs+qTzguqw!R#zn39}95%<7q4%Pc>(@+DoJH89RvFSp0g z(saUa3N$7M`77wCEYqE#v}GnmUdt{lShitoFpQ6>Ev6bQvgCVx7~dJxC0-&L=zl%z zMy)-mrh5o(w2rjUlg+czw*moB`wW2EG44dX*`WkWE~`VG8QZv>*=J@7eO@1)$hRYbc6a>rpZ-Tu1jL00e}s5@F7-4Y z2f*J~l=u3`JJD&F#chrw|wC0klh~jaD%1e>2>7 z;aEP^3H<%-K&q3;>^r8E>wO?d$}sM7H6+g+igDcv9{vX^-JzZe*IuX&E;DI}^)+^T zmG5}Z;NY_c43EA#9;*@*(tWTKy*SCA7(Tm{bstO83J=9Dg!=@3g?$@gnc}Yx25smb z$Tmq&394rxhkRRP)UUn!b$M<`-O4`1DMoMU!(qFsBaM*~Nbj{d(==y z;mlCEOWef!ZKfSvx+=mSMibtN-t=xytemJKjU*lzTNq$GJFwXTA*>|T-@cjq{O3B zi2c8b3hqu58@ErUxEHko3Z)KOgT_K}VWBY+iL?*rPNo4~maG%t2EoPKB4YIAUQ-fi zRik;lqgq-yxw*Oh0iGju6}@#sDXB@$mZwgAZ7LJ}#i_gF>7DIYj8&2K$~0lqZwiBE z*5#${Z7ek|J<9J*hHap^t9eP0pdqCGyu0bXk6PVqAZ27_XP5IQIwHH>&7-rkvjO2% zA8(0u@N@voE87&8G1eHRXf3-1Jadws>fHseor@Eb3p;XlkMA#T?(Qh6Z%gH@J>c?Q z0iKe3LVsDArV!bWLLMOy2rXNIU=8Brvgo(%M$+Df7By({dYa0?ci3xMZ3sE z0Xu;gB_W;oGS)x`D`4Slx5NEkVF-h22sz(RZWK<{yrk3X$Ok=zXL+)cus8cpfkL?p zaO1rEeAHBWP*EACIa*37N4LPU{%)3065SNLW@f;tCV{sIqza%5cn5geV%I5#;{}#- zLL2@3d{*QrMr)R;0f6Ya+2WeI&LV>9?kRZd21R9N4tk+pQAEst zo$WS+#CJ(uYsF#wdYbE0-r$e^lbp^Ja~t%b`wh2?a*B$IsQXHu{9BNtNW<>fd_`{$ zU|MPZJ%)ufR>sDin# zHb+}K@e~o7fpI_vy|N{+55EU>S=f>S{+OAmz6Jnv@@HcX2OR|8-ER1wxh}tJ&Tdyd z&riZX3qj*jhC0;oyIbMM#a<`-SXLW>SHG#1eHuLc-?wotn=Nd-YSztv6^g5>e1pt}KK-1ovm=-~cytLfsCY~$2Kpzvj5g@PG! zu|xAC>7?f7=H+=ncjd5Q)$JlW=W@-@qfkcG?cgwi!H3iZvkq{GWnv#6R*v@O)$OhVw5+-GT%WBl5B@EJ`*dOzV}pQfiKq6 z({pxqHclZYBh+n^q-)(!F+E-ktc(m zCB5#lgwh;hjJ@2weD#7?%l(4q0%pX7vijlUTzmsv{W25n#?cT#ubfZ$O+bR zkE$pYLd+`3o_Ee*F{8$xVc9RZTbfeD*RhTNLl^untheE!twsN=+>Y!E$#DQ16szsK z9;?4{g&P1a4}#ao5`Z^^S$l9?kgS^Tj{ejwUv`!z08F@YW#oE0KkWVOd{5dq9^ui) z{wKZflA)(zO&}UCjJ=Wnk)dDk^v39&tRdeit^LXmDMYv>Il;lj{j%$PuEN@;nl!*F zH}5|B8t~MuK$X3|Syt~DVC&VaE?ui315oeM!q;XDEgihaY-wwjYs)k7o`ez2-fXB0 zug`4B!?Qyzt)?XEc||K?!Rb9^EBdmqTa{{lw;z0bc{Ud69l#g43~6|(j?J$c8Vr(< zf!3hGs{^pq|L$%%$w1cyhY6GonRvnnVt?D4+akc{sHv&xBa;ch=O7B^U-=G19?cm6 znv4S53TZ#E`}aO5d3&Lnld*YEcR*CGL2^uo=K8CtkceT&7uAr!fRyUxtGGJZ~R z*ug41z0feLGAC|YdOFmyAodI-(!aQnc1(4oHi-1}pqU@Vli&o%AEcXi>2s*S3fkt5 zoc5jWem(?_&<`+JI`AYMm>3|kXx^+E=t)^9G{D#Q_xY;`FP5jARwC}XqID!B10Yp(x2jf4BR9fpmXH{G^*7KjtO244RLMUF>7M$*4z zql8N0L=qgC(jtp45Xl!E?s3-7W4%<7d8%MdzV+*=mHc+G=DFb$z=!bI4KwMB_bm1ENERLZxc4a%ryZC@&?z0p(V1TG%xQEkw2+Y-VU#Q zf0+BgZErnTP`c1u39SV}%AOgE+pAGCZ zc-5yn9jRI>@%xQ!qz)?>0z3o!Hb{gD#`Yc&;%O1E#}Wo?%L`foZJKM5|2(my&)$e_Sl61CRpN8G)k8}hvUgv#`_iCetkdA8zEQXv z{z9bvGX?FdLXkLn$Yf#8z4LBHm#yb#+B|a?(&v1A^Cht~Y({EFO_7Yan%SCwi~a<+3m&^GWe^rTx|B$mh|ygb{KV_;>+|ULDa_Is(OQ+A2fP~1 zjY{c1Y{Q)dnyHjIxi-4#M|05g59RA4>y&}TVieA|yL{!q|h4XJW!Y+QLmH&=yEaZ}~T?N+VYCxjc zyz9tMAUx9f;`Bqct8Z>m1IS1xFVQ!Cy!mS5@W6#>f7??vCD(gXqdZe_;gg@X6m5oG z4FGrOM>+|Ii;Ro}Qn~Xa9ugqEu{?@ZxDYUP4Mkj-ALL1U0BSaQ099DDEBuYkSN&9{ zm_8b_BH0`M=c>oBl%`F&8Lb zB?n&vYxZ*W!&QWZhM-^y=VDgd5qTA6u?w31n7}&0`z8y@1@ef8E@VwfN%Y%&h}%KT8JFUV9Lx7`MZdCulW?qsc)2_9RMRO}h5{rwh04R|Yj@qEJU zY+j{o&_Whx>JCnSP}T{2AfD%{U=_(u?KXZrNegXrSQYCj-vE)&?6JgcJwEN< z(p$o3#5j`~GpOOR3*dA=0{rP51iJ@I9easb;WC4)GT!{i$kEYpZDl@nJQmSFowO)` zOkDwOy?l5%MOis3EvyR};xtpHSr2sS?m$q3(je7i;=_}W<&S3}RWvPVG{p7h%@2Px z!GEp?oUn`d0+W42Z>f)O7u2pk@8=1Q;#lm9S1&q})fIu12MLmXj6y=T3u*Gyg6VJ3 zsV>8x?QSY+Q8gXY8HaylLq7SonBmHiA`r*$(EFzh@+6w;sT+HE75D)?M>$!6^{7_cn0X(_J0xH;2IhR*@34+A3Z3&`SFDUC?NfAyx(acVd&{SAdrFvR%Kjd zvDIx&@f5MPEqi-xsvQnpEK6vfkJv)gQFkfSk@!s6Y0^PJ1dW_Y8v2_~>;!+EdEU+R zx8?*9)wbWH*h#>nT)Hz)Ou{1`bytUrek=M9IwfFufE!!jhu!iw%jg`X@#$Krum$N(t%;?3)59f1g_f(PK>3t33hsQYMwNr@L(bD1qx>|5tHO&vM!RA(s!9^MM#}>c_27w;yO>1$-bC72rqT6=T;Kbs*9O2vEqEw_+^l z$eCywug&a+=xR55fWJz@`|)*y44L*L6t*nz7Mi!hFD`yF zG~viWpdKYlRl_QBS%^vp0r!0!e^Eu99D1Rb+9c(_+OI^kPaV~FSDXAyaA7Fx>421x zj=KELTbljAGdDR$V8*Q%G>y-jeBg5Nb(5$2yo6(RP&T*>u}ng!W%ytB+ z2o_Yi+KbRfQFLYNmc`cE(Xvw@obx=SMl38fma7t^oFY$Juvd_eb!;U+FR$KAT=wT`=OOCI(0zTGTuU;GYe_&9*NjVDvnANh&YTxpoFeYpmVv>a&v^J5S4~BM})ctse@Y5 zpe^P0z&aNj@uwISQnV43&HCFld-6E5^&ni9WTuvz8Hz0t(|D5XG%8RwZzWK6t zbu3#>?ny*sf8dR3M!*|;%0!}3tcS(dpIA-F4d<>o8+)xSZsk&nN9%`=k{rTVkM%;w z(Y^UOCzu7cQ{i_TH$78#F#(BgD1AO5;4w)c-kjWPqN@z0>w(ak3Iq(B$-6+9Pf5*i zBQR7vy;@1$6)PKI?gJ^eo|lV>D^={jI{p3Ici$I&x2xtl@SPQLD62r3J{1SS;Fkmn zMEAaC{BEmIpCs+jN-EWY+^`3LEQ7U5#MDE%Aw{TWMleFB z6t`_@v%)UL^4D=F=-Rkds%#$pcTiz**D3x8Gdu~^rL7oiuyzwd#_CK0nmk$~?C!3}Dt)GuH5s(PvFu)eq+vYb0q%@9nfqgLXUXROm5 z!aRcmca>C_33#ia6whS-5<`CJw#rBnC?Fjt6ir$wD{_xPgwHu{0{N2R_tw?>fD!Ge z3bN+o)Tj?7n$K@;VYRa)TT$f>ZOe-ENn0zuE3XqJ=1GvI-naT}c)JBaZ~)RpbQJ=h zR77k`hYNx?6vnBgA)O#|e$$pc&wx2Um7VH!K8_0J4!9&CpTq~@=?{CO_QWOGhaQCD zKBLRoT9vcmP=Xt{6{&;>lk2sT3bw?61Y-($#fEEs?@?*9qTvPMmADm|y`^uz3P)9Z z#@Vh5DN_lAjGzAqlnt|%jY-J3bVR&4asT@aY|v%w>A1wQgi7DMxVLg9_+8xDY$u~Q z7x;Pm(6TTm&w>nHMP2Ml00!lK8Ef4(pjC@e9ts=Bo&Q+tV(dH`dQy||QMop@9DGby9K?dd(}@|j9Q znQYOWD*+hr6-XWzZrL&Tjk$%@00uTayaSO?_vKAKjZl|%)Yyb94t%hRx)moCV$DpG zD^eXqGnz~lRj9&Qj&iYrF*(P5rPEJwPo+C_NE-bkYHm2scH|c1y~X|JzrKwS%c-f+ z0W@st5XGhA*^^#Vgnny2L;0{x#R1MJ+8fHN%mHC0ScE$O^WF5fv-RnF`zH!kJ|`L>I&hI&VFq_9sClS&@)>z~M` zlN1ED^XJZy&>P*h@V3gGdmg`anoR{s!zsO$xfdYEL4J!teM}ak&pi}o6s~zD8Z`u8 zT&O8NNa_rCT~{oA3uvDj8!y32=2ikF&F0@z(l+meY)TMmWE9oHwMP8S@E}zX26_Lg zEqmgz{BgO$&pIMjb5&F;mKA<1y(zZpNMY zi0I7)($7u=)VE)`aN=(&z{WMYG@>5c4;m27euU-G`?(JLZoPW_fqeORAg0}XBr*i= zdu^4>%T}TQICLb`6ln}$wZEE;&F(csz z8LK@B>3HU9L+;Ed=4BV4qirfA#8GU>)j+sl5&@E@2|*1Z7mN67wo5UwBNZPjSCd0} zui1RF-4TrIXiq*h^W%&JO+~ABeE>`>y)|CZrFI@~RBT^w310@Wz$M}Yf}Lynl?8xr z`hkmZ^0t`lk=?fyTEo$sU*AK+x-08fa(_50SJT)wPt+4W4lu|rQx9D?+gr3of3C!N zgl5DT4)C9~bfDxrh4=^fwCp|JWNgI|@YYHl$Pv@FI_CnURMEB$C+MhNx{ z$3wd1Pte|}D&aS9X?_d1-eXh!m!8Fvf>m+61$}K{JkJT_0G}2gulWY3be>>r21q4W zoK#yBxT`IQjE5=>$3TS0y6lEwm-bZJ9FS3mu0_cVgzeQlsG%_eQ3-DXgX}e;&eZm3 z39L1MAt{WAyZK$Z3L5?Sf^%98o5&(rs&g`E%E=v7zlL zA!{PxS63+!<-M5quP$WhI96hyk${;yu=9B<3IfR{8CU`LLb6)ZYf;NfTA5aG z9n{2{B=xv_q*uDS$#8yWvG{Sa)u9A6VUtx{0piM)vC0jNpOaF{S0|lhF1h6&4hgZ| zL9Fwr2T-F}au?r*jP)g}wBVf>rE>gbu(vZ$cpfXt>5N>BLSp zZalD^xsXRPUJCK+;C+)xbQZY1JjqCXQ(7QGq(RNCq<(IRSL(*si2_i)Dg zmzsAUF!;_+M2O28Xa31Z(C7=yLn`c4;4DtJ=-43=u|(nJiggeGB@b?mz5W=n1j0r0 zN8N9L7n;07n!{c5rs_c8FrVjq`b{?>D9C-s#YHfc?0(6@BEbQ}cpS~^>-oxKgD<$t zUP?YJxg(s@7&KvA>)AixwDIBz09^rB_8$Di0>UOG@O5_8UR}0n4>qDJw`c)>NhmpN z3;xz9!kH{#z`RwDca3t(WGyn(Zv_m7m8U?|i`B|umVP7;I+B(B$gfl(>L_gq=9AK+ zd^TLw5A`qZYI2EfOGoG);?>|UggU2`4l?bgjIHVjlGaDkDu>%-GSQ(yA=cU(*v2_OxZJvK*wt>rvuvi zmwD~?P=xi?_oa-?@JaZ!tS)o$c~eL{xVYDg|8{H=e%tuz|09hW%G?4;ybGFWQIxhn z93=H$Snk(%3x;R^%5q^P_y6uxQz?DpoBajmhbCjt(x`D661^d6ivG4`s*oD=Au2pc zgfqO~Th=}mN{-{_2-Z?cS^25D-i87|f9NW`&XWsbQw7upaw*vbr{$G^;p}?s>ph|> z7W>*5To6)9qA<-!@Bwc#Ka{ZaP#X7v5U!~#3|+gcAZE8$pf8n+(3bo*ss zrVy`^5=12nuf~dWJ6zJ%$<^x#@>T!4*U-W z+JXXU~~0AdMP zdwWKU9S%oZUELjVS0iNlen^OLDCh&HdgTDa&BL9|D}UK*6&&yt>=7EnF`C=Y^$N&tGE4`2^Ry~55ba;7NpvL3N&xiAOr zN5oP(&eVY+7-;Bn)*~E=!Yp$_yjEVU9M}fCdFq|$E#u=xMhAteV?{^1tT{(mH5>GM zff5ff>pqDqoZ;^s(t;hJl(B81p=j0kXmi+lkJvy+M`T@BhNs=r*f2KfOdIUDq9U*& zjsL|+w3y5SH2PJ$;O^Gzj<0y?x1=3Z84A}=U}iOSa=Vj+eRT4ABTjmWB`xR8Vr+zY zg6WE;e~X1aKcx&Da~2#o04EE`y($wmwi&KT?!9dOY>?^1OtSd!*OUw%?hBun#i-c=5Az=fni(K~9$e<* z)6eeU6L~I$LCRu>XyE0S-Vg;NMV!^nPE!JdtrY;xwY_xUp&C}7U?7OCUR4wnt~Qn# z##R)5pb51J)X5Fqtx~ize{agmDoFuEFiD4aP*@t$zaAh&JQH-Fg*wv>1pw@E?}?QHw4_p?%Z$%5Z~=D0l`vt z>FNNXa4QPArzZ~l4VTp~R#BmFyDFaq$CXhu(^6$+@GCLJBlk!SHyRnGu)qXcQCVS4 zja#A8vSe82%58V;Y}bX)hi&n*R8H*zMyD}w-Y#Mc#GpdhjO^xDAuKgZGdmY=5>9B~ zSn27GF07;nBo+v4cvIV0OC8ZJW@hu1czCB#(heP=*-pN)y0`vbif6A9;749B$u&3a zYmNdQch~J;UOC%%>tEpQ%;v9If^kPTt5@XLP(B*FB@`ssNEdLwlcj-!TRBvesciV_ zSX$UpD~Jh$xBqDflw1`e|*Exyn8F1;=MfcH|z=$bQlO%iLW6!**XEyeb~Z{O#@Cw_p1Q>?Ieu^R8&78gNTw z*uAg{q9kVe6qJOEF<6`an+Y!{_8zOZbS{vF;aGH8SKPb=&24`r+`#O!4Up^odHPVI zCgBFh(W_Ibvshq3Y;fJG6dqqE{7&nY@51N)80+4Od&L=LXaha37Q9lO1fVc+A|^Jn znxm|Tr=Wo_+3evViuz)TB5F(}&^XoOj=q=X~@;k5140y7)x=r>Cttx&9Hu7HsQ#L zI<~YQq4Xh0B7lpi>&?Gszi7ahS5s;H{q>>jwr8r2HW*w=%I?O>X|P5`;Wfw}?Bi2yt;72ml< z*Z(F#$aP``kY> zVeuckt1W-Ia|en)8mZJD1rbf_lB*}Y8o2c6-5Q4^^_MTM47(TmGw^Fhf~9s95|-bB zJ$Ekmiaci&k1VFWL=!esFbrU6rqjaFTh0Xp@L~=e^C|WOQdnx)f2AN+Ar*7u>h>K| z4QSIY;Y7F;7&@9%`r($z*U_ur2F3=eM&AL?Ed@&3alb?%sEc<`h;d1!wUrEZtnT%x z<(W!f;=wFGkNPG$7!_W@>~TdC6SbVMXrI8E*k>R+Y=xa|F)doR3YGc7f(+gmmCd){ z(98lD?h1|5P@xAmZMV7sHW&4~T6A&#NVQ|;r63PH{=DV*C0 z&Aw^YFYH99b=1hhx?8Q^Zn?V6SCF&P-e}rIG8PtJD{ML1iA*~YEvCI;wwT0f{Z#?TscssQM#^9{N*Oj?U@h!$+-f;e+46J(qgw_Y&gVh<6j$rDX8QT8I&aYFx zn!k2d9XJ;OdvJR~zGU*ri|C0D5n@?+`j(Neex5&4Vk%gT5282gW^~4eub=Z0w08u^ zI%s9Om}m!b!mjfdK<*$vBJUg6@Er(XRbo7uX`I~kr3BN>q!G!kE(}45-1PTuKDWkJgClJ>q^TB`KkY z5X70Qrz8#q#ct5PTI?BZ4!Z?E5BS7=3Yf7REu+1ub0XfJgx~$10E81rJW&Tg;c4xU zz{mqm5y0txvr7P=ZrE{A2(bGlJ$}XN+i<)ESaLA)$I@7zU@&}eb=wUauy5rrwB!HY zb}4AZ0BqVO28_Gw4Sl%|4H!U>=QlPZ0@Dluxzwu>(2r!p{lcL^0G+LXg#B@?)giF) z`Fc&vE6J=yva?olXs?EbS|Bhsf3kyR8rjyp(spQ=kmHV8NM>baRdhKTWlana z^^}v0|iH$I1k0Yt>F@ZnDRAX?Pq%n`2+RtmV(3~4@Uu1EIv5#&x0)tgk z`3xM^J$X3H)ip+s9n09f158GhVLXc=%nl4RM%`$2(kL!pFtvz>Z-ZTp-wO`Aoy$MX zq31@5GW0-%hjf(ccXGFv_FfQ_DdMEy_ye>h>fC8hi=V-~)#-mHwR&J$aF$L7v-ht$ zi*>PYm9!Zz&`|Y(rEUaR%?Tt{p&YR+X8GfVXGiveu`PQro$EL86j z_iJMso^po^eCFkF@QO$gMo@2T><3ynd!au&5BNDz6Cb5%srLHHVxlnQlfT(Bw9cX7 z)Jb~kz;w5P#uGuTT+)a0Bye_11l*7C_P#nUiA|T%;jI+0;*BbHw~FQ) zqHv_o``U-uve>n=X0`TMGxEP-vA{~6MC-r0ZinjBkOHy-*nU&iyk1#Z39S)|15O>i zqSvH7J!mu;2sR+-KNW@GUjuXTeR*gNXr8cD?1$-_X2P`&HwyTm2db`)zae`_SH+0R zq|)JCz*kM6(OBJcAjt5eQiTjaD@(Iv<41-7{O4zd%=Da`qWuFaqv~Vj(^{gA8LcGm z{A}uP(NoZ-{Wn2lbh(SFl}dSsfW5(%+msH9t{LQIkiu8Wp)_f28?@+X^PXczz@j6P zvDU~_g%A>YG#>0!;&ZUVAaJ0pkFnvv@$YB_lVj98p2pFmH^3$W&(SSc_3>zI8Jl7` zQ~@qpa3#Jw(7K{)PL&ORb8m22Q;ShPPr2#M>nShlr3gsPZLhi0E7n zXrX53MJ$wmr#toyWj`AbthWu`9BWKjzKeb;a~+5efniAv`ML` zW;U;mH^TH{uS0ym!GX5FQlyYmi4!O#(T+GKcmn3-0!~J8;M|)H`Y2}qc$~uT*&Xh| zAB>AB_7(|x>^?_u2zFfbICY=)r&p8MmJt+FU+P$9SfiIDZxzQHEPtrE#z%^AI#0XE zJ}Xxdpz*T=YdH7wiE2heHbk!2I6ky2tF@2P#^d<@x0BX&wdtsHjV!p8pF?}AW?sds zx%Rw*Oy)m^lbpc}EC|;C)a?VV44hMbA^toNS-x^H)BES*zJkxp&0DB0AKk{@forut zN2AVUoZ7_DcfPB&(1*~SuWCF)9`tgvUq6B<@w&RHpAC07I8y7qTn$PYcaj@LSCQ=K zY9jJoz%{khr6t*x;D9w6T`W!2%u6g2VyO4mBFVY08vcMU!<9uup>dR)G{5su5I4=Y zSqhqrR0k^*JP0F!GyVDGw!5;nHa1Hu1fo6|lya~KRuDAG403?&V8$^eOLXT!kzsNJ z+GAt`XIJ+EXYeV8>)6POe7g>54Ew;iE#}L^poz?D6uOxlwY;N$15DZol+J0eR|HnZ&d;4mjIC!r0#y?Nh%K@WX0=GH8HXU|lEb@an5-Aj?8bw3s`M~!;ijJC(1XIR z!H!=8Qo}G<m_Cb)0r!GVl zYu4`v!)ot7fIpg>laT_-icelT{TkxZTx2lr+(TRpdI`RGH#;j zZt*MME+bca%kxn3;x#@9ytg*HeIVNdLeCeUtg&aFgkz#j0Gj%C;163sp;cENkHMlZ zrJ(PW0c#Tyx?IS*OSYK#O1B=pF zZ&kfNkWDFCkQzLAT?>o_9~7?h6j6dncV?=h^p1(vNKr0Ww2(}~Ff+nFy+*Rwy(`8e zx9nwX4})+zfT)@A!9XXi<1O3zecs8mV?>e3wvZBByYLYTOfNA&mV~xZ>l(E82oljH z!>={2(U%x|GJ4`9m3lm@#9@DA*vGZaL+CbxcSx3jX% zKTTSD#qCbnFI1-%)F_TXNliq=`4UTJ_1Lw~T{UbOD*KO2+^wGyZQ34quu1 zKkc1)R8!}=#<33ABGTb1bpVbQML?SJSQ(TMf4=zrpTDaFYHv5L*hQCWE zI9)|k96SB(kFgd#0cLri9UON+4mIFL@jpsjA?;eQXV@Mx>JC}hg zSSZZGKPH}yEXNfvHJwWHw&00bRmgkK5X6cvG|<6xH&sX77zZ9Jx|W;MN88nbw*mn| z7!+scIM3UEmJtAL{_luo(#83Jp&OpEY7+6;#)@0FUiMouyk}8Z;K?=_sJf)KAO=~P zbZ5R7H_LbNytR#7o%y$C<|X+beCn#UT{0^9qMcb0tJRhmQg`g=Z-QF~Thj|$!pFHR z3W7aC;}@vPVu)^#n2TuK)kIpQtJOs$hGyalDZ-h(8}`Vnlo#nQU!~{C5<^KJxp2vC ziB?qbj&~C^;s=18(Ne)(m>@7`JG1lio0Y3xe@mm$0#7p@Y@L{trgA2PWt05^mem$< zxV(hYZb&%js?LYAESf| z(6US>!`Kx?HEXd0(^RP>Z1QJQ6LIOi5hqB3c zT-mQke7w#xHEuG3XOcUX0?FE#y+hX{0HD!IubRy_mAtM-^+l0i|D(iq4HQs~827<9 zw%Zj_;_|^_hdlAP?j?lHh{feXYseh;3BLm&2?KHbTTeW5A}%T5tnJN$-eI4!@j3JA z;SrQXoAIZH0YvNd6y_854{P4#J7SWoN#=SZon&xls@kSAjI5Q(k8HNg+GrfXeJFbR#d)P6h+@=33N9V`5;TZ_;7HQl_> zN1cu{9J+RjyJwikiw6e57N<)-bHIGDFO5^+=g@8xY`xmZOQfqZA*$H~ zH93E^W8t+@$*`f_pu{>>!&Q4NyDWRXpf-P+4%1Ufm6>?R7lxl1pL0MOrtNFaofiLU$j|uTOyhEkl+xW!PWMAz zan;fjJ~LmeGv&~XCaHcDFvQ*+1A**@cCY1{Hp91oQbhX$x0@H7a}j`Akri&8zPG(< z*zhfs=(FNppK|xP2`rs& zriBR?f_#kGzpBHKU<~Ocn!XGnnmu#fVfZHW^FODy2g4M!P3K;mM;22A1%}FZ090}h zl-s_Rb-*oQhI%U4hs|dRU#Ec=HkQP+x?{{pn;*IkCD_^p129`!dfqQ}JGp$xQu`I~ z!j}cL!65P)Y3&GtDF&SYgq#aXDp!xr)40UP7Uz1}(3_XT`yR_{ zuJ+-Ki?d?bhJ^K<%G>k);uckaBx&%4yoRebYqgL@Ag&)YEV}T-YJL&)AakOEYVsEh z#+TB2id%Jjwd#{dwHU+YT(ehEf&5NE8mbkWu!4M_Y5qRX08Vdfi53_|W|vgI@$6Og zY5jtYNM64Wcsn)UC3{bIeZqZ~$?ge@Zk|Hn_Z-229R{1Apz<{rs`+vZv9oZJ#(iNA z9z+cNXog(_-qOu(&wcA68IoN2@Ip)Fmry1i@!*lYS(52`5o1KEpEr9wlM$^q{5sb$ zl4$^-u$F=7zI0#uL|AM9|GTQl?kY6Y7A;V(2%CpeFg$Ve>O)W?`MPQZ?uXVwVVHhX`H~KIMr4KT`W;8etGngo+tB~dt;~R z;WB707$a6zr)isnzL{3SQ5PYzdJ1lg3x8MsNJ=ERoTp@Ay!ql7?|ufs87gH1E%gt# zTe4r_6rh>{Slj6-Avayk&S)DsEQtGJI@UDgh-&%7^~#!yYyZE~(7i-S*fS)sSZ zL(n|HT~&h~fNcmOpRBe6#kQd?cEinG#C54?sdb55ICaB>Sa00A_hrU7f{lg>Z<$4||qE(=E-l~-!n!iqFscL28V$_3*<{Q>EDp(}}T4tz6Yq zSsVi4s2?RKy^TZg)5t=n#ZMbmRtPkM87bGmR2KlUeXFCzuFWu_5HwVsxOXO$yDDcK z{^Q%+gvnVpOmE+_ya*ctSZb8Ob?pt5es!TecpqwDHq9&2F1#lvQ3H7t{{8RRF2K!f zh&AUQW5F+lHP`Qa%X~{>yWYr!y6$YPVN*nAgW#d31C*du024!%-~{>1*`HoxtzoSd z5N$yE=5b8osser*J+`N6Y0kG(u>RyMBtJ!R*-2!z8Z1tfV>mt0{A z90ouoVyZ}^muAL$&E6K0lKI(~w>2HI1g-80cC)(nfjclX4*gTcge7u!E#(z+n{6!2 z|BhKw4Nm-104YQa!;!vTD_yM=ua5%P{U`ji$y6|}gHNX!oLOnqxmOKQ{VZ0{uvXp5 zwa@KC6WiTo&NQ&dLLiN{8yvXEFbGUskXL~NUC54gGn#1PI84mfm&C%aoL9aSo@Ecusy&%8T#TYc@#=E1%P1gMh=YVk&_%j51pNz{ZU>j z{*X>Rpv(GloZQMtk1O(iacGa|mwyB6{kxcHg*~N%NmyCI3?XX&CtoV(lUh(B zfkR}OL2+OQyeNMNck=RzThMxp#kB&X)UfJvIJMla-Rr_m#t%d-C>;O~HY4Lb@L(tY zz%Hn_rCR6UKM_>=;TQcz?1~%jG&VRoDm(nP7%~og9}EC?-{j`xIB@ zDGz^)2tXh&_Q18|5~#aQ?YFg9m{HHi6HkKg5(sJd!8yn^oCbLcRa`}2>n#wj{~4aP zAZJ_C@x1sm9xZzrOrZ}>C2-Bth>K(Q)vY17zP-_-tG_KeV4N;!6>tPDtzCKb zSG-yR%^oc;|MP%;sj-U_41VKJNADRzOpR2-{;I@sA&ex51i|HV+?Nsk5nC+?Dv=3WF_hSlUl$nG(&98k2T3 z0+s>u zd)XiBwB50R4G8K-qxZT7bzl%U5zq%^$Yg|m?whMMEa;Ke=tk}$hBji0Ah$WBNDTSn z!fKV9F#X8*?2tTQAH8hu-TOM~D;t=)==l2fKLSZI^;kBofr`=}gNsnbA$b)|N)&V} zuWA>RZ8i&cexfWF)d2&8JuPI-dhvOg>2$jjZI8m*9pjgd-6G_GECDc1l=AigKitE~ zvaQy~DAR9n;`bHc;VQ@h%b&8Lc^nw~_+gMG7xQT+MmV|QeKd~4xRc5?s?|~OJ?2@# z`*iWt*x3yceNe%0Zml1V_*c1O|3j8K88QbF?YH1Y6t;WtE^s^s!29UYeOv0vnDkW> zk!2Zvnw_t$k$*Db2@z%ZkA(hmUmw)Myha2bE?#A0R{qD^@@xv5ePn@Be%5$OcYZj@ z^4l8yJv$m+1iK`tXR}0e=<79fMb5z;jdpRJc|2vv*Bx%2(<2fw5LrSvM0Zd}%xZDT zxfJPX6UUYJywFs*ZHw8PvFN?8ml_ViNfMrkq>=rDmC`X2{}!dm=!cbZHAvSR_D6=v zYIE^?Q^?tV=UC);5tJ~|tkNDe)n!D<%vY%t5lyfy;I?G?a_EK#NZm#6o~%iRk2R_j zZCTWI2fhgrbJ~=K;_sv1B_q8L&>S%FJ7AL-Monav zS>1r!EZ1g>5cq6eCJXeSx$l$%nr-Y#8cVRZ5&a2S2)QOC+xXcPs|pp@B4rxZ`_1z# zuap=qWw$kGNN(`sf8g}EnEwcvp0||Li%y^uCh{|-?5m!g_mQm-fNy(4$F7np7R7;+ zeLGmj(l+&aP@#4J>2-N&zOr4y45w}NjxWZN1 zcX7z0Hb4Oeqx|B{ZXx3asQ5ZrurXupe&7#ufJE@K*LyefXNJkEkDe_9;XkF^N*8?1U|9-QK~WH=D$YK>=r z{{#30J>V2|2uf(Q)8Hrq+6&Bgv1b|XFxa3q-PG4s#sxm{=H(HkGb4yjeZ3Q{yz0(&>M@O10tT!QnPvieyD$PYd}=Fmjx!Ehp%P%$TO(OiSC z^tjzf2=9Orn&vJCj({<&*y2ll-kCOsr^hiPKUjArQDfF2UAV6NxL}oC6&DbvQh)s8Qz-um%C7 z-*vKoA6zq_|4jy50UHG#9+@Hnu>@_p{!eD1+E);qV)*~~Xi=l*Dku()CYfG}oGQN| z%HT60neKZ<=Prs(1q+y=LyY92(AbNnk1E5= z9r|-J`YCL#O!bg!aGQfM3Jg{XC6Qf4PrcjMcOr|QgG#bGaYKpE3dQco+dc$sJ7Ye}xhK3etM4Tu@*4u+<&N#IEL!GvgpQQ{mRMuGxuL`Q6`6nt|1?1TB>&ST4p&U>-nv?q!_ORF(+;c8e(B+Btv#12c zgD{J}U}(m*HzdTj0w?{XPSKa{L$5_ak!7naJ)sk61Tn%7rs7%lTKQ8v2)}xvUkVVn ztdj=-YKNK)?pa0OZX<{|yQSdiC2+RTUI}JbC}`(tx|IzU>Y3!YL}6rni?B?zeaz)z z7KMlaGccl??{@tqX6?%RItDv49!Ie?-^zh4KWz9tM<4{RYekt#auLna^YolT^6$Vl z2`DEEOPI&YuFsBRIs^|D9*EzrF$gO?DVoU#Nnw3w*x{fc%;<`l!$p#~gvO+NQC%O9 z0eC{du%kFODLY8!>YnH|Bt)G9j3^XP%M>iTWJiims_aP>Qpr|Z?b09@GR&z6--@3R zY&0keSf(I{ON8z5qI7a$ZO&qm_n=hMiMgjw6^(`CU@{xTn;D_bIxT1E^FZ0rrqH}3 z9&eG_SV#e8;f@o$`)F4ZTNR5v5Mi=vUn$p(Hr$K4@@7iA5l#OFk-Ox4?1G7cvaXFy z5FMI!S$F}Q1}V4|FsZvCx5f$uJLLYY=wxFXihxwc{Qs7H{|X-+ZsC6od+EQ=42L@P e|GOtCl4?|0$@@h(FySu9S$}E!*Mfa+U;hJb0}SEyXFrN27(5HyF(zsHMkQX1b24`?moB#55a;43j_-mCIlPYT{5@@2<}5j zfP3zWx11F@J+-^Uf)a0)z-_`!ovo5Y2oGOcYn<%*p?h&fd$* z&GR`Im-GK@!0GB?$3@G`=nY=vp_`I{Cjj86{ry9M`X(>}0Ik>yIcaUb+{5KSV{Pv{ z$&-0*QWrEdQ$Sjd=rlv9wInXCtjwb5b#yQXSH+J{CRNqTBa3AnGqbA8g6+1e6HDID zI%*7CZgkX%gwkJ5s|%eHau;HJ%V96-eEg-DZazg9e@5SXiS7R zzSk0kfFPAFw}dk^HnyCe%ves2i3mbUK=3dME-xo1W8nt=tp4BnYa&fjsjb)zyP7CY z0hK*on)ix!l45n6_?nq0fRd`JoQ6i~j12(HI0`5vkkNaS&nV$=7E$bKHl!511^<1f ztf4`Gg^gXx8DR(r5)=Nvr&IV-%0N<=&@(xu3pOAWVJ%~zhEhNNajomU30teb(Z*hE zPbVKIgXr)bQXmN7%Xx*9oBY^wuDi6FweRjwe1OQKLWPkKH6ngsYy`rn?0KdUAcQYM zTC=GNA-j>-RN$eep^Z?+QVy-zYV zHKnepiJGknNmPhfTQiT0jHF{?dcd1qwb0_=;GqA_=b351Pi7n%G5zqpim%+TgM+D3 z75(-g5kf*j^E!R*fD8Mco*p`WexlUW)bDM9%`?oJeCPg+82KG_k9k>H*^Kj0fC`N9 z&&m5J{{H^L9$T1dxxyOz%Ytfo&(Q%)Ow7*jbyhs!Wy-bL0pbr$0hf-uUe6D{*P-3s zTsDj`p7OvB*d!!q9+sjENA;55O~)6;WWZKr_zm)y%R3IYi0f(Js5t8f z@f+%d(jRUPAEm+JGPo_#3D*#oR z2t<7jq}<(k04dH)Mm9D~lNPTqh2k)TlY*KWp38De)MB$MBOl*m@U6ejs-GKr7X)_q zwY`5}pw-}8W}Ir0Xt)ilh=@pRQj&tcKH0{`#@gN<7T|Z+QiCl!6Y& zxzjVyc!3lY66`5_R(Np(ZQnsqX0Turclyt2p_9>9gP}QQlnDt23B}WTFO0JrRaqWO z++Jwqiun@)g_HItGg_}KX38~AE-tFv^F~HgsYHEn+}+&=Mn-z-ZHCtl4idny`+@yJ z)Z3gOk?ML+M}ZnKw!iH0-Krne9cW{ui{;ntUZeSNb2{j&vHQBjd2 zc)6l%x49|<{RUfHR8;mm4R$WBn4BC+*-CUPH^ku4@;4sK9?Zz-=sDrl`FYZikPrYU zo{XJ0gHk&$G=^nnl5US=N7UEz24)y>#P^1m5HD6n&DN&d?rff!;eD^>Oif>%U+-H@ zw(2}Ch#0BxzGF(J5(%IF_zDdudzlk0A5Q}B?(W{c9JS@c!osRLR#8#WFf?4)@_uV& zuJwW1+Qx<+4Bq7A7yhoJzuR?NX#h$SN=F!xr+97h>)3T7xKB7zPI2vKHCYJZ zg9~Bg<)zv@eF};A(D&2#XsHfQnS#$2r%Wwxq3}=_uZNADJsceD((-a@c6MA=7Fm@+ z14OyBzR!^A2TTb*K8}wS1%ux8RvXi$=Zy&9BE;R+fcl1pO8&4H0J=NtX6 z9?XA7oh)&K>EVAHK~rB}|A>t2JAd!}kYBU9T;NrmgMroy5rqp1%<8(ryC~|By)RY- zg;i~FpX$^)PBSS!lG<#o#j8!{1VNuXdE)mayB!<1DdhHsq9Zf#>LARtHYPb4-_&nC z3gUbYpNvQkHdH7kIBx&V$;-=|l9Cb%t^i#lE@ozQ4GoRNyQf9dj!nDY>xyS=_zm}+ zGCwzTc1jKW@Ob?@xU{j6zx8IX5(xRZIy62Wqgz=`Xl-F(G4az&>E+8Nt==ZjPx)=$ zT*;6cscPkr5Q(uoQ4AnUBKWznv9XhBbJ@fh5~=u6Esxt#yVtoXiCPq*Lj7`qi6!41 z5vE+)l|ar1=5u^`Ih&kD9TlgmqaTiY^$a$sfHRU5t3 z#^Fu%SI-^G(f0zd;NOBC9v+`PekhN;7Z@%JBfpwB{L0F0|0{lW92SDdTe?7Ob$3J4 z+9KLl2zVH$%YFxot=Vxs?!#xm$>}LdsG%#l{Dvd>A$_>Ani@p?wri7FC4){#h_o#b z8I5r2;~N)?@ZO($p>AE19AP9RWLl>t7(_au(-1I#VKbUaQy_53i^p54v#prNG=O=!*HL2EL+c~=v zA0l4*_PF`_LbIj@!oaRKn!{0_>VKBn<1MG@^*vfI&`?2%M-SiAd|XEg#~w z3%P#+N(gHYR#lNE^7*>}oH9-EH+-J%)_YhvNN>xrfOp$l^TMwJ4_XBtDfT^$KK^V9 z3*2VEY3Cs}lROnA8@`Bren%g&e9WnoBdZd{Mvz45*Tq3PYDA4u<$gT3U*f{w&n zM$&m$?sy7~+xhE=gA!U4K$7~Jl%>}>6k*=e#Ff;gJ+@Yqk@)v!Feo$eeb9|~&$wZ{ zqGXoVCNC@WH^CipG76JS9C$zR=5^%Iv7Rx1{>^2x{khVzY&%EhvsQmf8>F{e%{tD@ z>1RMhMtf|eo**g!4rjOdn*0D8iW^94f>{6;-&@8{-31l+rJLsM6t@N2)36F{vwhw& zUU5*-aHsEmaP$7Ma=7ek&-GfXplccZ6U7lrk+z=LQQy~UR^!D$gNUlPfl{K8uBMS% z*h2Tb<4$1+^T@gqDv}2Bn{WoAVns7B~vEsM51nRF(Kzfk0ZtcgNt1j`Vis=jUf}TZGTps571>fa>^d zMz697YU;%I{{MwI-?f#r(UQk3C2PyyG6p9_FRlEPwrwC6K|RpFh%jgoe2Uj0*gYZQ)%ERdEP(Ad67oA@Hen-j6rZkn-Qv`u}mF8sB8- z88^l@anvoI6QF!KH-9hW%$!SfrZB%giFlQ@V=g|z^IDmKx*>xFRIu{$@*t-)87}YI z<;A^$%TJWr(n~ULerVS6+gE$6%@|$w+?J`PsEC1xghbgyp|S_00tP~?i1^sp$gVX8 z28IvZu-I57HXP3XAc=TrvU4*A`xeiyuB>OXR7IB*P5(^E%fn3@e2}gjg-89o z6M^_T<~=n%otl@IC>;SoR4DiNt})azf=khAbwEhHGd|OZ7!-H!-Vycm_iuvyF)%t> z&1=SzMo&iv-2O)PXYp9Af%~9MNI<}I-D<*M4B6 zpa8+65sU4OC$-w_ON2r1B|^<)R6b6F(h-gNxz}f;qMNYTW_|JXwV!IPFoCqRw0?`% z6JryTy5QeFs#)A9;0*7sc67`z3&y4?he^bj6%N01gJCpAR4j#VBv9EW=k+6@jzOMe z8YPi$V$q} zUFjTpkBEt*T-$#^p6B72nwtLQtUtH6%y-sPppbq6vPe;JF#!olG^jdYEiI^kY0#omhq5tvQ3}OyFe5B@b;N=#rb=GmRAYQj9#-=?UP%Pk z9Y~jreZSh<+vo5Qwe2@p>+9?4m9x7`UmK_^owBA5#I6-DVmvAFD^v)=mkb^@tk?%j zULC6t_}k-JpM8?-CV++zYpJ=0bu}Gn*luOLO-pmXKCu8g-#yVf`Ex$LNMx7}CT^Yk zrUIz&_5%WuNAlq0H_UJ_fI3qeR7|{ld<4|gCeHaF5PEp54qLj-Mj-1!FA zf}1QgmAMm<*x8>nwYR6~TuzGk)*ngf?cVI`9CVp;&j>s3&s77VD{X;R3yluA z3)>NBJgu#*Cv!%wpy8`7)8#X7&!4GJV;;yARRz$~I`W-`|3tJIr#jyv-~>w3p? zJSySPgM$P1(MYTQBy`{a%zTaC!$U(d=H`W?!?iA=Bq++`kYm=JAgsI7@0Iq8&DcQ@ zU&Y_j%LMKI1OaVg1d1UIRApy-k_Rm%B_(SJ$jr0SmZWUeqsTCo{FoQ6oydK5NX2#X zLCoUEkn(zC2Oo*{+hr)@#&mOv{|1Bd(NgzkZ?4Ua7_;@2(j38A`YE2*Pw`)IJ=L$r z1GueE9s%WNrg~XiFHH95YiqAWMSYK`JUl%=sI#36anyDW4qho#o5kqb6wHle^VQi5 zlQ1ze(~F8yN=QiP%&EM1A+4>g9pO0t4|cJNm~&?W3rxg6(FKI<`k{;e0WUq2SsH_u zf{e%wT;pXQOja{QZ1MD};_uHcyJA0iDpb-Edae7Al%mpiOMey$FI+Cm@-Mny zz)p2gY3{ED#O?<72Y&NV4?*0)NV7U_pIW~z_G6~E+i`DjEzx!LHJ6MAaF`W6MWj@%e z^Mz_6V72h;;A6(ieb>~$Qx?$ET02_ByIsk`()x-*?!H6WDqdP|;jJ>5VO1vXLqpw< z)6+)lLXWgOdQ`;c1z&=CpUKu2X@3)#hVLTFxb~OgF z({LpFXe!*vlgC2H&ib>3@8PS3XPQ>K7@qFP1E~62@71x{sqUeXs_U^uk5%c;D-hud z3+aH+LF=yNZ@!c>G0TLYj(=BBkerZ!10t?&whM2zIXBtgXPv&ft}Y~7)pj}=p8r;I zC3!0usbUh{%|1F7qj_k!|Jf&d>0vVT4@G^43VhZ%hAvH%9#nXdu7+Ut>LI=w2I$}2 z-I0O*L~C2yzKL$_ycLLPf~y4G%gfXR1O#B%bZXF?tI3QB|G`_q=6xWY^8{Ww?FWJe z+yiuUgB%7Ws^(Xw;hcvqiRU+MBDgg05Ml0{X8>`;b3#&Q_;mkV@qDWixM&9QOQ&S_ zmcI!FAdj4<>)F$>Jhw;Se~Xay;M)K$&Wzz7S(4BYt#=3p?td^B*cI#s+tGTc^vsr~ zPj7c2N3~$vZKwK0@S%{BpN&=eWOP*X(b_l3kT5uh9mDw+^GZrHIwimTqnoQkqtcEy zPTgy7C&JOOKZ6idF?s;gL0ETCCQ>8lsefJn&wjShqgn$o}uYSDm3 z*J6j6(Jz!nF#}}Ak^fYak=<4bj0y?%GXdyP^7@Y(uz}AfaXi<6w{UR|g2txMAd{z*R`3h~m(zQ8FRXXc!(F>$^VPT;JY~R;2NNU^kwh z-cq7qP-lrAaJh%h%F24M(q^>hagYR`#Uf8s@cKE04z}q9CEV%7^ed~gtwGI9`I&?5 z@q%Pdla@7b8}j>o*v#X-r~NK7Q^iF0FQwyx60I+VUbci&o)D)-cL2;euvEzQCsEU9 z4%gXFGAy%MAnltA#Jl9NtglMz?P+_fO8w!fR`5y$uT_g556nbRJd~^_jah zdHnkI%kS5Z%u_f9t&$0rMgu!1XY|L9cIghFx&+O-x8)3uPorkgQ@n8?m|DtxYqq=@+{&ZEQwCb8quo24j!26=oJLl-=2sFEN z%7{rwWU6(AbPxjUPo8zdH|;FyvQV^d#roBtcEPu6cBgK>-Pf^->r80^ubqo5-I_F6 z(jI~ar=qzzouJcqI&Tp<9WQ*m9?4g^vJM8bVUP7RHD3p<4z7|?-v;k3**3c@r(|Zv zeDggv%)#a|Yfk`e7eRw%0e4UDu#XG45AC>gb287gqAxEa3Y_QoHpvaW&9y8z1YB3d z-leD03ks6(-boF>{Q_WCLom0T44o&$em<5Dw$!}uMb1x7I(ykF|}PdDhV;;r(AEwiJIO<&tai_Kf??xeKeRaBLgC4(-o{gE>-KTKe|}tgrGT zo12Be(-ZJX`1o-tXX3yo*YTR&RgRLC9}J54vZAhuFBcQy;^3G2^OI#SDXUDrk$_?> zs-fY$JHwDG$~b8^u9z-!{+6}5I+Hb@LZETw5VUdd!K46>XL>+45H#K2Xnj-@(D{n@ z%C=7bsV1qkoOasVdJm_&KTwTAjvDt6u#eoHdud&b6ih6)p|Y%w?YjmnX%=_qX^)83 zj5dRA(8por?>*X3{y?Lt!gAvI%EXB^&c*cXRH^S_+#k?^ZVaS!rW&jZj*1W2L?5JbxHt9c6 z+7C~9PPpSf5#mS0e^MH6jel3rc;e<;*({zvVA_{Vg<9~%bPj2e9J!Ht1fL?lc+@ID zlf~}?yKIx;>~DCiC{3TKqMxoWOtk{vy$o<#Xngq1=TJsj8S9-gbBp(Wv_XTd#blAZ zpmVpiU~zeQiN!VVP(5Q+auA|O6?AoX*_XLNRUb_Xxo`7g^c?_m@S9{fc}_tS*oF!0D>qn{Q^ zbQV`7CwJ8)0d^(iHlX!fsCnRlizDu_X`gN_vfbNDv8EEV*o8_#PHv-g4qO# zi;MF+8)W5iSrUf9U~5C^95A0l3h;2}eNaIG)SGM`I%Rp9>u}<*v%Iy)%HZgDu<1bu zZf=UnG`%sjA+aXkd@R7@A+R<{gA0@!G}l>H3u<5w7DN%diwzvI@v)I`z8c+{Dr5XM zIOZ$((JuwLYSMooIfKhF6#+q$^1tBtzwSl<9=!h-YyAi6QbOLslaK(OtpmUdc{RBj I8T0Ue1E>)!3jhEB literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit/1.0/circuit_library-1.png b/public/images/api/qiskit/1.0/circuit_library-1.png new file mode 100644 index 0000000000000000000000000000000000000000..0bac395ed940f9b02ac4908f191f11437866c3f3 GIT binary patch literal 6289 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 I>WJ`v13V_cx&QzG literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit/1.0/converters-1.png b/public/images/api/qiskit/1.0/converters-1.png new file mode 100644 index 0000000000000000000000000000000000000000..a791a9bb8fadec8abfe52df5ee25fde4255bc095 GIT binary patch literal 8320 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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 zyq;aUqPOme@u#$hAjdA3IXgt!z;`P+cIta*?7^)1{l?8!?*a_*_ozmbxSDi#W4Ovt8waRNtZ&?$mdyDuD zk2+=SQCxH*tqqA)jdouZej8EIn`mOUBjorNEGSyfaDGv4(O#0+RQKBsN?fk^8sj`A3r zl+3mQFIl7huThN?J3Xu8%^ZFw8gFD3$p55_h&cH)-m!N3l-t8jYzG4K15VyN>7m5| z+d-W{>J>^v?`{nV8yGKwP5Aw==Q^puVj|ztpaJ>)xtdtja)pweD^6?jpYgByGYI*2 zX0-Ky2h#C-?I=@r=dD>$s=(ZQ6uJyl3@Wqg6~Wg45UV}k>|AVf%_?MwOVFXaNgz4Bfj zXQ8Pb-qp`(TEz<%YiKjm!r z-|`cBN&PP)foN^zl>##SRe4ZN)(?2y@qw)T)@KzxC*q7PJI1qHeatf%V$*S-lGsH4 z@KQc{b0C8zu^^=91-Tr5%L@40FFNGxjL1>%^@WOuste-P>f+;mwE9FU&6X(8cUYeM z%F))6?lLO5t@Dm1@sE1`wyhndm{2AyX_YczUkp3XNuTgLA=WG{{}%8h`SZNwjBF{m>7>W&ky_bB6`T*kwU|CpxP>T zk18S8)u=nrvnx)l8!;@Y{5SrI4?RLgDw1;E`Nuoaa%WM51lJTKN@^96m1oNO^{HF+ z6UKz6z6lAWWkiuRV&OFaq|}X0T}a9d5nRpH{EJ3nHU1r^Wa8Jv6@pj<2VvotC&_J2 zH1h@eOk5cFb<|)t+K0A10V4q!X$qGnJ)(?F?}oOQ99Uz6?=-yNSom!G-6EaZ#);QRH;LeGO_X zyQngA^D+qOu*|hlLBBGZT{C$Wi3d-~gl{g509V_=#TgK4pe*{zG;Quk+uSTBjx6!G zG#2}?_wCAe6Gh^%@Kp?+d@Y}>!w$~G5Z=3LOv;08%fG2VM(C5~c)O$(_~%$Ba;ud> z9u&X^cVJ#Q;$grmy;qu84 zkjXjteNBpwQRHJgFx*bA(o!}PM=TS^L*p)57M{?w-@-$qxw$;IE^Y#;%L*P(YOjTm z82JL_2C#X6+>j^Oa{?o~hA6v?=$`~?FA?<(J5%Ca^`f}^C|v{723p0Q8X$N;w8 zLa~a4cg!`AwpQan@cAh6H9L6EDH)p#)tCWQ$RtO#0jx#~0BsQKOyae}T3+@A)H7=3 z%^0@8hSC(0brf-QKwpO+7Dn`_rFI84w$lj$AQV4JjI;qigTf9>b(kG#&rZGn#WOa) zM!!U?PjzRD3%D5z1N)IQ`*xDqlV)#3&H&`N)11|v9+P`Ls}A6_E8xL2khzB7ShWw{ z=yt3k>al~noZc?qfvFeO+42E=f0~oAFx*x5q)@)SwxhHx(uuL?)`Ql@BE2|FVJw)As z_`B{}{lnVE^~gCGsH3G3%t00zT55y|md|NSAM18X#t*jMPA~gIx9I_nGw51M=ovMw z{Q?7xVJln!@@)+Hpur$PY_HI}%Abf{VnZD1b)pd#9_>%YO9o0|1UK8ksf&Om9Mk+9 zJkGZTc4ZL9K0xaCf?lhLTc<<~OTNhm;BZ|U^?jav1McfoCs0NgfMS^MKK-AHw;H2& zfA`L?li2`}YJfuQI^1x&gm=2aZw{WzPV5JQGoy&5t)q~CV&wS-?|Bws_}bSD+H;Cv zO9rV@aCkGO+WxRhX@5YxtWNCk-bb=m3l_tfkD8h7heG6H6hUoeFt~kddF~t>HwRa5 z$mY|6)`F(Q%OHbTGWb*{@UiL2xv9Tc}1_=#o790Bc zG;d;?V3U|J(V0rFr8BBRYKx>-;iN^d7r#f$saguSo26%#=!U8Z z&&l5Rne+as>bt&egIyQ|&8ax!6LpW?v79y4g4)WX$WedeaO~OTxRT(yK9fXpsf&_B z%rtm@IpEjOeXm*JV)B1cC4=k(UwZO*b=%i#pD~uzk=V!_$gYerle07wgkkc>}ifET9lp-BM7fsO+NM&@Y=?SV*43ER^W6);L463veg56jsa=&(9He zxz6orE@zf-|NgfAYQTIR3+oa9RR6|=`BoG1SqFK%nKWQo6marMiCQRLe4 zfMjpab#mK*U)M+&14^4#w7!GL9z49Byg0M%NCQsZfn^rL=_5=dc#0{>EL zBNoZ;p&MV)w~gJIxoe|FY5pTpwd*N-L&UtzpQtOm%@1;`=O&{gdCM=PtKVCQOjLKej+TYj_wGATgOT5n| z^*MzbK42>jzkVo*+O6XtcKW4G9J1|b3rrfX9P*Wm&L{~tJv_Qp)&`hVdtFck>O z0-~V)PYq*6ftdOK2Zzal`1nBlY9MiAkjy>MT}P0LCrDi#q!$h{i36EifbL;I4n-i> zN|0AQC?F6N&_+ftn4r3rpu2})e1c$Smyq!ZAx90Nq!baI7ZFzgVB?~Uf{{W@Ebu4K|+Ouup_z2ZV)kQ>N;g*2N4IjoUBEl<=PoEEyk1qyv z1BV6jPu!4UVLDA=v-le|EIb<@A-MdQ{qbWlt0?R6sDJ;#VR1SHPeeYYq@<)tJ-AWB zvbeJTQ^Nu^{)59za&F+Tl6wTt@A^E~!9U-?m$v;64&$%6QNvoC30wc+|0Bab;5#%Q zcLd=(?{xl84FkQJ#*YY({0D~_r{0iZv%!RK#ooTH#?PJM7Z(>-%yKs*Z``nr&Bvgf z`TxOT(w`3x55FZ4eEa!7ILxi#EWGnSI4phW;^N{*+4RrW#moNn-_v`4R`J*GkN%zg zPYpB1>svvA(^#YakB2!aRdkbtD_qmKu`~$S3 z){*yZy~RuSt*IX<~Pi^@ZGRD=AoT*6vYF z4Qp6?a59}K9}vfme)Dh4mUPO|p;fesLjK-Ms8M09XJm(E>$kTPHOBSJg`Li> zMcy8{x!RrIcJeq@_P)Wyjt}1BV$)6hA35z-=DP4UO?KZhta$FG_snvQ$9Z@4rN`Z` zPrhrvmAt=*XD0u7H7(U)UU<~7{NggNRo3UZKHHbg0v4~&P0|ruK825GsEu_;w*rd; zCwYRcBH$8Ih5>iv)$Ibie*_yn%$u)d(B0Ysv$|>zeA-Ds3sUDk-5+RY)ottvHV(ft zbIUG?mo|7I@;ayHLmKhlE~6+ha_;;{+O)X*m^YTM?d|wja+Z=w&$*q<=m#&db(v|Lm5FIb&WW3JnwVv+5r z8zbeN&(IUNtjI)MtvTj#vPjuxo2C6W%(V)WT#SzklCe)Kf6}v%^I*PqU$Z!@r>KT= z^7leSXDFVRFH$0H30338b5-HfEaUFnn6WKQRbFurhK#eik~wSxNPpjM$zTlQuDYF3 z$5FwlDV3GA`%cBSI5#bh_2oxBG4B_yieZ^Wc9~=K-A;v}2f@RPzsp-W2`rBX;XN|Q zhW7QuV%=%+Y;EzGk8N6<(O3eo_Q}8cZ@vfK=>1A?{Pf8f5l#PB1FHL@0!<%U3k^g+ zS2nawL1Bw2{Hbp^MnhMd+CK%;q>mmK-3s{jz3X;~g}deVa;p=~1&Yy`DILj15lJZD z8zBaD%*PY0**eIPx)kc`_Z4EqpId`$`^gU{P(EIM3xv`~KR0xgcd_G`cl{Zi8=o8K zR>NWV(N1Mk-s&^ed^L;q#xS}-@McQiUteX+IQ^O07i8-4d_>lxLv7h~@E0v}Jkv=t zWybvFKHuF7NtH*RWq+$%-aVYV+rHxc=cxNj)1Tx1U&nt=aF9FKr=t*k<`c(Qv@7N7 zWG@4rdjlm{6$M$1xW9T7uat7!*eooi$1BA(2&7Yq_$6 z@Ch!REdL%boM6VMctaH7!;LYA1{##ZyOh>7US8K_X8M`I2*)aH&|yLuee9QE;li^g zie(%s{lUOqDnCc}qtd_q!~I*NaUqAI4o6F^B7yB6(!VEJ0%cQNdg`lw( zk`wFJ)Q2e#n78fXkwrmizXxL7juLLd_Y2wrMn__ngh)Ua7;^WoyTEjUGUdTO9%g=U zjFJ%3gG%}jK5ZA|cnN;SLuDmrvZt3#8^?8qKIrps_Ah)D@b%v1-u_PFXyDTpr{acvA~VqG9f)s36l={7Eh@%W1jcZp)9I<>hVW8UD9shln!E#~^;g(Y}Rk<2rx+-Q9YuXv&#Y^M{#r-K$ znQgC)wgqSAY`(Wtt(#X_7Oxoi?s8%fy7^a{x+O~7^LXis(rwCseWtPGp68c2mwykc zCIz0*IbKl~T4ly(lnDN%NSMe!_iiO4#wkR6v0ayb=k^u)(RhAn363(YE!F*K;^a}# za7DzZWpI4d>#CGE+N5b-Jn?#vdo9*lv{z1t&;Mk_nz%lgWf|IPnXJBLK?WY-WJqZ@Poer$pPwV$1gLvhBzI#;DKjAQFeP55_!}knJ*%mN%C@`S z59~akjx%8gYpO~R*)2VEDfLf|vyZ<%D352R3`Cm-NIM{F5K=+i?faTv47wlGt<3WG;d(alf|cG| zpO+KG3E!8-RS%;*gEqHLPb?x9rQiC@e2MsO@WaM%=k>?sKTTU_m&HyDbZbHXx>@eT z%P&Sx$YlTHrqUZA$cZaQg66t^-SJBPD#czAyjxSkzx{$@&g_c$8$Kj{k~Ea!R{b~Z zp@EX|4UIrVX&L;&4C>2?noNh1tDY`zjXYHMv7(TF49NHX%N8`R{63raowoPr8nObr z8V(|P9L7ApOZhafYk4s1dD$Ikiv7VXBisA#F@!)uJLH5V&5S|jylAO9w|Ie0%w3#6 zA%(!F_j4Op+mT?KwA|M89rB;v%o$~y6?7$iyze9zk0A4Rzx$@p5OgoONsbszQ5}W~ ze!A}W`(eH~dst*r#n+x93(C%amxXcC41th?mWJP9f6DeCo7*~(AfGO<8b_G!h&hS=vtats+1C| zkHWTiRfv50h*WsS)2oV+$zSBprRNaA0b;`(M)R_CLmCN-0xcZw;MNGT?wh19S$Rps z-8=?q2*SBlcY98@K@E7aqSi-sNA|UB-!IC~JC5ov9_vs+DHPpXDlnAM?u6n(Hyc?Z zQnA;a-k7+MsEoS|Qb1Iu`>P5EhKGtD9Ak8qNdgwVk8}A=b~O%Y1H~@mJa5GkR{_z+ zJcb03Jw*41m7_>9Wa%ZGiOV3J-zkoS;#4NY(nkQwZUiqk0#S*w??f==OMeoHXKM{W zDk?Q*hEPaEQ`6fM*~_?GO4Pk%(zpav1Cf+LNO_I;Yy3ijq{tJPeJqorB-;mOekf>1 zG(k^Pfr29u*7_7NA7R_ckTxM~%^k0EsZplHnEml-q?BUus@Tj95Y#Qm85dPC7LSNl zs-EB<)Q}-m776!D05TGw!u~HO#D;eOtObXqiqKd>!u_AgaeJz3nTeFb5gNu3412&- zcM2~jj3Oh6xaQV&c`|UBv@FGi2toSPu=+_Mxdh*BM?_mWu6zd= z3PB1^h!4JtYY|R8s^NrmASSwFz=R11Vf%PRGsF#4DFnOm$a`+~%mA$3_s8VXsS*{b z@S)T#ZbtewtcTGP`JptxQ0lgQTAgdu5`KvH&uTh;6~1W~M}C$T5X1IeBb{_INpO-s zO}8!r>m4%2n0Eeba^7o8Xup$wqFeO1Grcz{2q8^bJe4+TVZ@Y5LeC5Z;6Q5t8RM z^z4+O*n)v?gg*61nk!ohkwThr-2*)DLEO`fu+8F5J}aRdDzH<%v2Kb8>KJLY01t+& zFOwW?H@edAd!KliAca7SH1fw<9^Dk@uf*&gjq+&e=NAk)uUgxjqT_6bP`bR}9-{`D>O@wq}2=cz!Bf z1@kM1?-E&+5-VT;9$x3ZwW>R075a%)T&Vo&u?q3^7x1%6BEwR65JJTcl2A&b(ozY+ zip%a0X`F(|+^fa$b=5>+i2Q;(YP{7rf|8=dO49jCvV8$%-m1tcNKp%EY-tUsg+mqt zw!%Sjgh=c@b68ISwpUe68ntNT^K8xvSnG@U+GnQ(FTlG*UIwIPR-|4#L^QiZ`lTeX zKwVKO@$I`*lVkufiwQPx9Sq6KKoktE<6V&_QRK{am}>naQ5 z@}VsHsKV8Cb|$h~hdRJ?z0P{L9??opu0pWr(i1~5-;|4 z6_553Y`gYGshL9?)V`J|;brUw4Jj{zA69wp&SK&4l8B(8jJL}R19rwhP3#~9hfsH1 zJ7sI9RaBD?Q&+&fuHd4sI5I@I_LD)zY-^?thQ3~#-40vgPV(pusLYCkLo~_)9`!xmur7b?uAt;D{ZpuGZT?JsncfYkw*RWea2Ofg zo9A9Qnou~eJw(!~ps~|uf{||b08aXPN?@cU9_u;VeDj;LBl z=6ZJzpwJEh>mZli0oSRgf0F@W!y&In{S4M!52Cul>RT7;I;}7bIVvX)?o5#g|UsourvxDa*e40UNy+Rh!CGmtZi$ji+IWuWJZ5X!N>f z3bSg?ks1JVbP&}Hz=sA9exuN#(Ld4%>+m7JWGEx^*qcK@R)_@5*AjFy<$iVgb0m$| z6O>Go_4DN=*LhJ4)&CNijKhJj-fF)$NM~%14F4-Nk1ou&Rt3J6*g29CA(EiEsj_tv zyNBc5;WW+nGDhGapYVd$%uglz0i+B8~LLl3a!&J1< z&uAr6q}&fY3kSY!-pLK0)RzMc`SXTS0D>*f`9Fgupos+Ex2R-j&?#5}7>?+ETc=pv zS2Y94cy(3O{U+lzSa@gwvcOR?emlCyq^0373HksS-NsMO*Om>dhvf?BFogAw6Wi2% zDhB@Qq~qVraYi@1y?$v9m$~b;xD!*y2jg^gOty%X-JNpsje^sWR-{4f z&IvXfQZE+_K7(7&q$?Q?4Vyry37i1B5(*!|6*=y#N5(=TjZ*9>%vpFamp zEqmDjS_caK0^7l&@3;67LfYyTp#rQ^!%Z1!FJ;6oZ0J%4)K*i0;{NGQ(rTn%%~D@p zh3@*gJn+7uk;ij^$h)*u04Hj=ez3d<85$>31P4vyRvk8HMBdA-Zi@e!84_4!u%+Yf zZ|qG4e8^YM$abir!O9yX8km~H*q%??QsUkpAhrN$(~b}02kVScGtpIIy=ZlB;B(_F z-5IzeWgdiMQki@CDG6*5PQ|?ygRl*t(gSwid^|d0bCL&K{^s+h89508zZ(GsI|z!Y zpGy(EVE-I}ZW>IOBlSAP1*Yyracp5Z5o)-{Tmo$bHVkz|Wbu$iFJ3C@W1K4iXM?fYI`% zvIPZ9tk)@t;!(@Qz7cur?@)vs-n%m>>P1Wou|B5LMt%{h0}0}rkGVb>-ELVpXpY4l zoOlBide6Q#o=e;BCWIUl3V+`CdfcfXVD3HDNd8gFx6ZwE&^{vNcG?-^+oOQPqiNVV zc>WOLHxbKTLwKh4b)yrj!;)}(L3+0LY`tuDuvv%=F(ETXD9rdnu)(dU1!z5)`gY=_ z4N-m$boP<1{{zdmph)HRi?C~Iq(>pIkX)}m-F|g$^!Avok?n&5gXlMCdiv<=@H&R~ zof%ATUGI$LKC3h-9gHm{4lITIXc}DYuX(@zd+2e-!sT`hMKg;6%fI!N;QK&j`DOIC zk)K7CAGFRgWao(w8;pyd4ddT`U5L(07T7V=z4Q3hGgxb<)5+@qrmkA=POp|FWbtw0 z=i@E??M~>)+4jYELH3{IKs*Tkf8j7tShm*cT-lJ3Jgdxw;zvy;l_D|sKu7gyDmJRy z2b!Dxf2x#n0rywnBq*?0VuN0F>^k; z*3tIk2iJ-*Mg5>nY7-OJVkv{yXg?@=|r<&$~xe*kbm zkH7W+1(V32j2kOe(pYKGn2<9kDKV<2u35;DB~NbX*k_usLi6tJYc!(KLyUKl6q-h* zQKv6=Xu0Z$Pn%ABHacpfRVM#X&|WF;=H1&TQJv$3SovXG`0cbZWsAeYk( z$2yhTu}wk?bx189)%5=fJQ}M^@6VgqqshG}o7^xwN4dIkC(I1>^izX6Z4bkny1W#w zFh|>TCNy_?)2KLa;;_S1#S9cwT-y}xCgO@yR957^^wX|eXF@c}UuR;p(YaR5^;sv? z8`3CBnS^TD2s4#QNKUiVl2n;YJvF>qp*7b*3B`1l)jRP7ccxhN6m}&M5Ara$Vrl9X z&tz%Zlg4?^6}Y?_JA{;`90gsgUu9u>Vh}A78>r8MBz8&Kue?=qP@1GP3fqB0?hWLa z(DRAgn?%Ly-Eb{kiHc3CLxP}xiO|9h5?x9+xOHJ_)m4@e{8wb6CyRHcS!ud=w0vdS z_oh5oTCFfXA_o6p#wXO^gRqzi{_WtH5>^=5qRXbN$8mk4m@BYll2l8MPa;A#>eN7j zlO3M00}%reiHT&zw2cYnlr@%VOS2On3vrn|c9Go1dOovVmQLIb5l99xu&@spLDv%h_CC0f_J|@-`D|e3>6$&JSMz?L`=e6fRx>147ye<4S3 zA|b-wHaGv6jZ`Oh1lfT_s4xck@nH~-=wBPu@Dc0nz<85F-b>InB}_q3hb%D}O)xes zywngTj!PR$p0FLmz{U;+s)QY=K){4l-#IFTn1rio*iSwxVKBI=AGXDwO86OeGi6s~X(uX&*#uO||*8EcIf zMBv}X_(+Gm(Iu`^THA_8!IvB>Q81xGC2BLmxA3QSo7f{uen$`~YGDjjLmoB{tfHrbTk}qkW=*~z!OuEE^Zc@|^2-G=p`XrT|V5KYn2g{X65Mk+T zi6*}}Mt?T0kud30C%OBPR< zCboo$xPXPK$W^E*#4PDJ2a?KF>aUe8)M6*BH>U~l6Qrk0qasl=P?xy0C6shuLR*qZ zV+nDHKz#^B?}vzK4ick=ETu_KITKm#^npK|$qWyt)Ryp)CIx*7N4Et`mx%ORaFP#9 z>q%35Hbkfnv53WXrd0^u6^&?3>muF6QkQ%VY0YHG`z8pLb?OeNPPM313u!&UuH^p- z9g!F%^Hx>77LBMd(Pvk6dXj+7qr6H5|bhgr77i!#8of}qg&B7@L@ZfaLtBemZSiejih0XC`{&h61{?N z!Ykn>i;laJ@iOx_=SA;lC$btm3dS(knQe&Al~|WxFkC0L>U;AU-=o@iBBB3f5mR0A z+m&2(TS&gKJKHcy4z~dbJK(L4&*jxjGMFU}b|mxevtp4HS4l5sNpdB+T$q$l3!2+p z9((L%foXFkBrt#i7Qlc7h~W*?VzWuyJXp}sm?i0zNsHO&WJ43V$TInh?JA++jdZ8W zcz#xAO=18QVBiBF0Ko@3U;zb?Aa%Y{kOse&F{rRsv?YEClpT^?j;O(=M`B_dM#yP_ zMOY*Upung}ee4ggfB^#lVtd5gU|I(ia=*;adRa2!z)JccadZSC#xTIo5aG&&8N{7| z{i$+3ga8&W_Oacq0R@mwrD^)2du>Ez`6~G#KxXe$Jd!g;9dRS)9+>~O0ic3*yW8Cr zAi(R0Rk~-Ngv_-raFEbE5ip~#&Bc4rWe+U9t(D+iTU?2nNGXoqDfeK(?10B!+1}Og!0S7Dq0eCNntY>{K zsI>iJseg#v*UVNh@?G`jO7TQUFoA@t90M#@_W@GS00>OL0+5&d1f(E^%V(aA8y897 zgKA`v7#5BCuKLnVvU$!|eEI_0>_iUmdavt%2FN>?pgjd(04Z34+}pk0`@P^BJ_4+| z&=ZLP3%k;~4}4pRjB5$wJHC(Ezkw+|gIE9nOt}t#00HPIf*=6z13&R2KNgrg2xx%x zLkQ=qCH9+$L(9MVC_KYszJ_o#7ppfAgckR6hy}0!4oEl_Z~*mlpTaXh+rvHG<2~O4 zzCZ(m2vo11YA=9+3aN96`8uA3DME9pz?L8Y2ABX0uz>$HSbzh#z?fjc?+ZT`(16H` z!3mf_1vr2w)Ih46hz^9P4@|z(JBh4nv_O0anKMHuX+)DCfJ|sL$lP2y6kT5hn z`rEe&e27?-HiRI70ziOhq(TO~!Uycci6KUjFh>6|Ttr4Z$c8XEiZio-G!*4Sz2MQt zwV=6zU_k}2MHrmCHPFQr^d6UcyHO#+4LQY-ERVtCAs<``#e0cR>^GWVNCaSjHGoJ> z#KLQwv{!>2(CflN%*jIGM}#1|r~}A{_{9q1NQb~Bm1IeH zNvSLpk7Nn6oQUcxyKqd18yqH+Aj*f##0HE26<~v<^cS3rzn&C{p9D&LoQQ;MOY;c2 zA&b5lqZ5dmiLac1HMqs{6U&CHxu>&8RK&`x)X0WlM#gLq(i}5=Bt8A3Hdu2ug3!y` zqkt;x%Zc2=fp|-W+=;oQ%b^^A0Z_G|EKUFOxJ!mY$8`3;Uh`4MBv}B0|O$ZB> zP8L`K&HO61YzYMzP$P{1C0)|UxYGaS^vsK7(NJkngy2v^^U(JEMwuW10uX~0h)oR8 z(G8GD9!=AN2+o~jKLlVrBTcyvfB-e^jZ!p;oiwkUT1BYTlUW4AgXz+ijK@CI&?uEs zmM{PeSX83hfE0Mt-9W=Klfy?T$>*?^2$fKg&{K!>Q$Y2-HIRZqEu57Y02MG*qWb^~ z&`?!13p#xW+!WFtWUhIG8sj{ONL`6Zod^Lq00m%!3AoVd%+N)%F$E|=VO2N*JXXp0 zQKqX>Qk2o308xh+NHHwPgg8yq6bm-3N=LEPhs@Cq2-FHt${t0CEhPvDFjIF+f^r}^RB@UKeT_{c*gby**eyJOB5k}n(1w+*yANOhm@Nx< z^+|ah%_&8QAYF-jO^7T-#3xM%h~>bkHHc-k+JW#`u*^*CBf2C=0+v16LV&#_ZQ8LI zNiBs_gXr4Tiq?Y&+vJ=!RjD>F+6zhQSqt#GR%nG#h=f)shfw$e#!UjEi-38A+oRLX z8nw}T)Y(#DR{&^IC;gD9JqU>fQb;2Kx>LCyAO>wHhjQ=-f6xYIUGPijIGtKBf2lBgF=V|Vkie)&;?>(hE^cD3b5TV z<(=fK+=ocS$)VX&K~7=Fg;i*TIUoZdK!|EBEbgrg-Ypm*e)`&i2vQ+12L^6n2Cjx?5C&Ngg+`bKA#k-}X-$(L(#A^y zU0?>st-BNK->2N9sO(SHG+wwl2{LeC7k*&|=7tC+U-L!Z+ocH=B}t(>S+Dy7VjzYP z_Bst%020R7n&gbV<6E5VB9jON7=B_XZs2MVhBnh&0UqECyuSGbfh0IwmaRJrFn}Vq zl~rRkFZ{xLlh6N&5QQjiV;F9RdL^yZG>HWuQLp=fFZMblt=%y;iGlS+IX#F6wISej z2;n`597e3G~+WiiA2rhBV_m24HsMKv>ad1)BMc0A$91hGpg|mJ_5SW2M7f6I?E@=Jkbj%h$FVT{&ZkepB> z7KuiHVsvN+ba3Hw_~|Ex@A|Po`_S9?01NVcyNcUj$&bEv6(&y7=28* z{%rqwkqHG*feD}h%bWqpZ0l}%Ycv*#U&iWoaEEtz2X^pkC~kyY9vk>rY=ju<&*sMg zhyV@9J`C98O44BL=8v))N7ls1%HEHLhH~k)PmmmRo_Bs}*Xp%1JCDs=N#tBGUU?^sA z24;sS4gymOZMin;gGgiZt4XA5bOe&L{I)(B}|hXCc7 zjqx)HL|`@242PHWp3!El)Cd;|C;sslu7+{GN$u2WB>z^IAOH$5(*I_pBp${s->3hR zU}GzHVXzjxS#2E^ZwT-0@`?E4f*@5RN5NYOYtD6Z$Y!79XiBei01ePziax1>AOLhg7jlt6_6bmS3RnXb z;KU5(@|c))WmS_Pka&uhg^OqJAQxLR$3R$B`p~2a0$9oOI{*@ZX$pLD0HDL8ba|L} z_g7Eoju%*NZ+HNZx%3Td*2ZBX_e8fJ32y&%-In%&h!?BJdZnbug1BPBgm5lI=QraM zqPLfY_ibGE#aNg14+rs+phH~kR~G1d%cF#*h6#SI^U+6b!Vi$t-zERNFH4JUe1}kI zMSi(x_RrcAZVUL?9SuyXZ*6e&TWDojwpK!Je)Br(!#SgJ?UhKF8?9FPKn1r8v#e(0c~f(ismS$eq{6@ZdS zXV-Me2v{8GkT>JFw)U|rjtljcQ0Rt5iDqz^)6$6C`4i^6)AfV8q+_QDpf+`{s z!GsMTwsP(aLIZ>XEaSvkdqoi3)T&pr_UHw5(;{lurlM^5tjx8fDdyY>VS)vq8(0uE zigfJhvnSh5{^&r%X3x^MYEY0;&&;znTXXO3{cW1kO(m{nDjDiomwNer9AE&jV8Vtq zuwbE>vE!6VCYEpB5khp+3HU(+kBM~16}qwa9fJ)z_|aZbm9ms9T_*_hy1;#jzkwDJnPHS+zw~Xh}#i zz=jm^F?rvUA@#V?04iYl=X4!75K@qmA^Iw;O?q*i~{p-m(uzes_g9)+u?%TZ@LZq5S#N?EszDkvdru~}VlMRG;}V-iZ&QBEPz zisn(nx8+=q?|lf<$43U+!6Gi)YRBOU!E5xPbXf2ao^h*v z4)o6HMuLFfOkfQvSR1&K*Eaydq+I%YUe;K0JV$AeHxs~@E|`%77=3^OA30d19w@`s zqz@z{m;iJ-^MMEmz+1x`P5od3FuTPtZ*0MpMgWwhFNkl2FXF(eJOViU&9I7ap;$;r zfPvV7fCZ6D3I9@pM3{swXZK5q%zhO@n0#v^3eZ57lF*8z!3YBg_z2ZR_c|-`ktH5% z&)8sO0hEm-cs^XuT88MyJ(i?&=+c`-NI(HDa>j8l`hW_Q#S!Y!&3b+OWJwhHkt=1X z0}X(Q=TfQ4RsI8dFd1Xtf>@He!36({AM6MMiUzF&9snf%yBP;TDNK;~?IQ#TWR?br z#{9t~f-ni=bxKH*GWzk1Fk#?-b~&97Fo2L686on9DNd2B?jr}V0IFEf%aZ)@A*@^_ zp&%*3AC}}%;__rInYj@XR6v`aiGVjX^1fSDZkz_K2rQe$0#sEeCA4ITEn!l_V5Kg4 z1uaQ2|7J~6QNW*DnSdre;!F`%^q?kv2sAfxfQA0)0~K&U3J&l^k5Drtp4(_iuxYL} zlBA8QlV(ctXv_%Q3tBtu;h=1D(xpPgkRTZVOS7bb2t>dq8tA|VFi@gAQN*5HTMG;k zb{1EPk)A-r2?H!p)Jw7;1p)uvNJLrUNTwQeq8*t4B{>s;nXXGo^MRL>2;hf{PE(c+ z#pzP?*~qn|v?S%U;Q>^D0S=t%0~)Y^1CTnB(UFd>o&|tTKVpEqg5U#pj1vMD;DD-P z06HAdDzdmrPN0%Rs2ybFNaiXMrykN`3UI&@mN0<`K)?YC2&qU!2~pgBR+wQGiHl4I z6HpZ3XYmmlVDYmN=}phDv&1J!;#v~Bf>E9%5yTb-Ab_`qB%>^uVsi}&UmH3gb{_y~ zGcD4a)mjy+u;tiT8tajF61c$ss3}P}D-seID74Mw=}3I~(?kX{zQeR_78Otd&2+^p z3_xyft72Whdc_D$!Vmv@I|5FccvX2M89-`RTLBADU;=D70EkmU-rbtFB;0+Ng-^=K z1sfm*Qdoit6p-QN>^hQ9#Jq$9BjH!KU;<)?dhQ%OWQ10n4JQ1 z^-r+6v1C=G+aKYrMH;YHe`3Jb4iUz>BR*_dxCXqdX6{IKTyGg_9C*$i$*s?NPj!tr z+n_qYC5p%q1B~0BEu85>nj!I-Q(6=>^)5-~yUdLbQ@kOTbB)l{?~b_I0??Tt=n>LGcJpRud${7}T}4?%#_ zrNaW`a%1Wg#eyU7ttLh14k5q^|MUeq4#-~( z0fOCUE`Fz94XBAW6fQHc8&vA_TgnM3c_ z&5e(AJS5S6<>!lUxrB~{@84C&J&a(>#F^9e&9GJ62plC+Q0%dL?eWsx;2AG zz}Ze|i0Y}I<$N22q#rS5T}Z$i8qHrvAY4gE7)11wfYd=Ngo5{I12O1J68K+dm{LOk z8vzcRFudFHF<(3}U=@*7Peq?dpqdc*o#4G7`Hj`{0l)xBM*-Om5$cXEgn|ij#VIjF zE~x*TIdD(WI~eqPkVXPX43t{3P)RU;Eu- z#Z5}{#GoyD1PMd{X=TXxA`T5v0-W;`6%Uot9t@NZp zuAw%400d~(LZI7Q23reu#C~WbWJcz_-6g?H=79)iM=&MmkqazdBB+4`0yzJrKTQAz z;o)Ki8^xhWLB3FAvXU24=BvCWN6?^;1tcq~WJri)N@!t7$mT-Oo<~i9_dSHnoo3DP zWnTskY)TDp!XVHsRnQa8`k*GQR9zbr5ix&TkX8ucyZp3|N zqr#kId~U=*mP8pWC;&jg95jL`VwcG^eJhoX(>m{qK^3>Zd7SUfaF5B zSx3m}ocg1xX3LpYM4Ia5;hDyyYQ%Le7R?|MFzFea{OYw-D)U|HH=(FTG$}|7fg&)% z5G)xuLMTPFr$xMHN_gcBZmLE&XcmGiw6cb*W*k|TB}@px8GQeOD%@)#zyT9@D@X9E zvI&WuUYUiiOuNR4HEIi;dgijGgcW=OFFY*7@`5RJL9Rq<+Z}5~Nb4g;MW$*hB^KzfyR|QO41S>_bD#+QYmF6kPdIzq?DXhX(!bT`d2!X?@ z?8-8MwA~EO_AAC(M6zz-b3$j%B1%wBlf_mMW`!CyemhLKq7E0(Za&l&TOh`gn{l|((Y={Rz!35rb(*pm<+2( zxM@lz=SU2JDcG&b-h$C8Yha$m)TYFa66Ld=hvANijgJ4FwO*^+QiRBI1QR?iU3e00JCzffWn^FN&2Bo#dld zL^P7#(o#gz(yn(5u1EzexHKn*^7DSSdA;K3PK0TY;L zLtL#Qifh50EvAObO9r{0sOKK*-|f#n5t0{iv2UR;Fatj=@pf%pP~DctM%rtkW;@B7AS^gjQD^*X0Wa4!Z!ZVIpPb!e~iR_zNn z>xGub&sxOiazq!v0_5Jp89cDZ0zd>$a0Qnz25a!}7Vq(bjuk(I{9^4x@5A0g zB3J=@!tND+2e!IK9Lq7uszg&*0T|!y7)MX^kw6dsaQUjj5UVfyT7etL!N`FXosz%; z<8j2A0w3Qf?(!`a|1tV?muUp9;BGNQaPlXduPT^AB1|qtk;EBOaQVW*8gH;0v+&{? zD@X`ICwp?l!U8Q%s{)#GgEVT2mNG^gI8BK#`|$MbjevqK;*$T@RO{Ov{@>@}8cwstf5nr{YEvJty8H{PQV z0Ky4F?l25P>cYYqOiL191pPwv*Ksah;4ej#vmgiXEz!g%Sb+}*^e(q?`(E=m*`^hs zu1Y(DGXQTQkaR`lvkdPuP3yDDP3f)Fb5~)sM)+&ovNA>3RS$Q8H=8f|inKUSbWfr* z@D2kwWCKe>t}2AGA#$}vXmnK*?9PC7$u4a63Z0t7bVFn;Tkuc=0xJ~tk|{Oh zIs-g7LtI1dOIzK?=Jjfn?zB*~Q<(p3Z%xlVJA_onDrb*19I(PSpLG#;!4WS+N~`Qj zue39iLsJ7UAV4)l9CZ8HHD=>t#HjKr&+h(=vPCE^a%Qm>KO_?zwi;)!W2gQ%knpegbZz6i(-~MfY|y>*ydm#2jnOOowYWKSbCw-62B=AREDM8BaRikQFI|^@CgjX|!6{xgqX9I0BwRPJqEc9Sq z0(fdrbQpejLp<+O&A=bbzyl;e-ZCv;L&SNjwdH#FhYw{Jyf)VkLv*urZ1;CZ5VlCA zw}x{uk1xb}i!Do#zzkf#3ylAO2*AJ#cz^^znhW}>>vF7CchxRJcr?w0{{s~fD4Gg2&8$Mi@*z9Kxu{~a8tw*bHtZ71cxW?Gv4r(!?pJ|^sWl_ zV5fMOORu0a#ENq_Oh~|yt2v{O01RA!lS8Vr?#!VJ8e0T8nRo9}*LF)+HhsP~LlE$w zPatRO_yuNj0i1cGH+l#>Ks~j$XvaBxKQugV#2Lu=LPP8)(Dlux@~E@LXluj_i-bh4 z0Gh9QqkBN47q^Qq1c-kGUdwQyJH-46!E@*O!@|LKJH+Ku?XLqiaw}&_v;eZNIt;vd z@OAgHz`C=8I$8kwU|av-tz$boAM-{CxInV|w=V>NV;xVE1PLs9xifkK%m{HK)R;2_ z@8XfHL&Th$v8L0zr%TSkQ-pEvdq-USCM`HbG`L0-fWQwtl1o7AYU7N`UO z`$AaxLf^tCoHzhfI+#~H%`-%pt60J}M86A82K0QIyMT!ozzj&h3S@u>xWEg*KnS=% z&|iQAl(+!Zb{InbT)|*QW3oJ`WKnV1_2zY=- z3_t=rfCOBC2ekiy3xt4@FZs|H{m~<=O;>J86u<*`01PC#2(*5ZyFdmM{6`D{TLbSc zm;xM-F?DY4;@5No-84)TfCn6Vxx0X?FBlkzf!edZ+rz!wdjQ?r{dsaUHkSkmq&^Ht zz6Z?atW z9{d`1Y}vDE*ItnDHZDV)ijx8*AtCs1{UK)j)EspZB^=|5x&jS6P%;9YN~1Bw=2FbA z%zAL_5CJnvZM6$LcrCWsJP?QtF>X7mGN5L7LBA9|Y9YRp{&NbH2^BL9!5VG6F)-$o ziX;Cq#d1@Ox5v0s3^}6C6DtE3%tA{o58Q(fDC>S2AOjUugkc4pwA=2n@NoPR%rFn~ z(kb#Bo9{Zh>S{`{7mW(=APgnYkVDyM8>k?P6x`_n6jKZ%j1*b4=|KqHJgO8K#axup z=@N~q!U219szl3rYm-PtAv!X>CE0WGy#)TyQ77R3q(zbxLon{7AA!6ysv#Sll~yjJ zDsnthkCO5_-F9PBDOrJ%lTH_4u=7JaM|8*q6~j=578NhB3C%PeW2)9{wJi$Us1AM8 zLZ|jzutCezJSxIAc>oK^4cBY($pi}M=ud4@P0@p8AwtZtN}alF+kgco6jr0s&2;}p zU3Z<7QeTe(7*mRf-O$+K!jJ?|Ny@=kP<rGm5-K=Gn7Q?Y7~ zs?Vt{cPd~wZOYMxXMdoTgyX(m@Yo?Z6&qJ622WnPWTi(w_b34f$i%TnXAD%4^DzOVj?p?p8XmNKWclS0w5jw`gOR0^`cze&FiBsCwzTI zpK>@AA z7ZGIXBzB9+{%Y1g8(uLxRvgOzc4C7b+7F0C0a4B%CIdXm z2WKWjEZz}>b`;78gOb57LN9+qNuE-cw>2UbrBEWo;X^LKL^qBA1`q$xN%6QRM5Fi% zkC_~zrHB#$Fa8mAH;_RLXn=wfl%Rt;Nuu@+M-(Y4?o~wj-XleFfxubheY0yN;>xH= zUkW90MPVRN<_F5t<-n9Epg{~|U;`ZBK$JBg1FY%oe1&|nX! z6dr}z8N^PWpa#vn0S-!cgBYN|nn5wApkNbw+8oLliHQOmlum;Kl>z?^e7chXtl$NXw2B9^ z@{=^Gu}eZd=~f$J!K26#C>Z==4r-9fq11;2{ahwM1xiqZno^+<;o}hj)XH_heYwi7IF&|IvOQ}N|`Hg zAG=nY7jMcz)>ApxjCf_qqlpc*b@%_Yh(Da=(G z6Q#GYa*S7J_s)}imZts1sVK2P-vA49zzre6Jz1Po*zN?w6&a-Rd~C=Xv$vi|zLo<8 zH`3Bj);Hkf0vG-nVz*Y8#MC+@MM~h(CTmciL5VU&G`!)EJ^0GMeB~wAj7SvA`7y*5 zpss)%+9B(-w3`hkMNoj?KUTpIhT!XyPmH3{SA~(lP1fEtdtyPUot% z%x$Hvk>gsC7_hbq#VAG<#u@{lFxFtCE{bG{2j>4yYqG&c!7n}gJQQ48FVJ4zNujY2 zQD^3Wv^=fmK?2}rP*y=2ub}l8%lZ=&`#Cd#*7UFODCnW2bYVW)EgJtE6im0xWglLv znFadAD%=~=*#@NyO7N5Oo^{bgYcRY!>0Z)`ZR~dcq`(FLWy-tE(4*m*vn3abg?FtJ0bCq<8JC7M%Ha=x zlmi^u-gfl*&0r4yWY4e!Qp8nm!yFG~3TTjeFM@!?aRY^@PFb`t10EDhLnHt=M;*Qm z@d|&u0_|vbatQ<=fB=+tOuokY!Wkawhd2LSf};LO5G)alYup3y->?N5ytQMw2W8ko z$ud!nO%VZH_K$`r2d(j~K^(Nb1SK%R=1q|Kw!hslbtX!%9o#RO<6VLg*2xrX@eRPg z{vPCrh9yv&T1Xu|N-+0!*Bc^$6&v#v;23%jWw5CL1fcE7XFDa1PXf5ZTRC(GX2Vf0 z!L6T!_2hv4_M_2`(Te8f?*2e;_h~Wgp#hPzO;*dd%zecB1hv%&~^>j(ANc zEJ6E{5cU+%p{8gHIZy_n%=TUD&F> z@ConGs-$oy_^<>%NeB5YC_YW`4DlzRkSN?s503{EGXf3%5ca+y8m@sHt|1zN!4^=# z68ZoQm{7_NPoAVNC>9Tq8qg*l@FYwC@)GO@77V3aQ71<3ZXBZnGtqd4F(anH06ozb z5F!ZBpbsp;7J?xeqTw4rF&Y0%F%{835CK5+MvoAyqXKv0+jJrbqOK26!4}f77y4id zSWzc%k;Pn#7i&8cs1A-BBot zP>f*FyeP3Dnh_O(LHo!-BQ>%VEx{pA!uRB`e)?)2ZG!)b#ur6SBK>U*^U-8v(I(I! z8vc+RmXRo$u@|6G8mZA5u~8MbF(br~q*C%1!x15-02QL449)NwJQ65Opav+ahx!Ty z^sgdLvLU+B8}G~|tV z5%9iL(iXB2C>i4Ef`uGs5<9aK4d?DL&Mzn| z@dpjl4axI(rgKcL&Ogo15Yh4=o0Akx5jyh#6ShnzP+>n;kQ|({f{3yx%?~*V=2{Tc zKyAbpakDxD!$bcw0vLnhJr7b8<&!>5&L*Z{DKm63)w3eZa}c8<=`QIzZ2|~ORABD& z(#8|U$jCv}k}V~)As6WGf&fE3F(3B96F2myAjAI_GiE4KCj^v80|rb{jzDvWG>?Yv zUNjnc(ldQhGywo6tuq-s5g+)WAMn8wlR-xx;zS82MJH)RS(H87Gfe45^=2+SO%jRz z)aYE)93M0xuOS)Saupxq2%Jd`<(;^hp zMK!?^(lQuAQAYc~7H$;wG&LXkfgd#03|p`VYqJ(rRRqtpl1P%tAF`EK^C2Jb!B?{r6~r+_MRYXZka)fkS;GX~Txn1%VjOWSQCAg7 zE#fW@kRRm1=kQe?c$FXa;ag!ZTy?@!0q$4waK{uhT^Yqyf5I^*kv^RDS&20$ZK7VU zHCy-LUi(2~H8vlT5Eb^cA(T}M&1FQtFk!Pr2s~jIV&N2ifee5^dji!WT9nU(Fd46_dy=^fm^xN3_0{9)>WnKFpCWKWN8HmJOLZTAsyxcYNx>yU<6@zBI|a=OKoBw z2h=7k;UD+GA3F9QS<@yKHWF8oTC(;e#uO-SGihxE3U=XXp_Xo;_85c!QA~|{&{ijy zH7NhO&>_$OR}YY9#g-;PcK;Za!DMz{+La;>l}6u|QH0eh1SAsu!BW-pOM4?-&? z5M49kM_(`|_0tS7_Fq@<8fFkOc$8s7*CGb?R3(>D?w}hk*K)f-5egG&ox*GxmT%Mc zF?H4qz4ae!awmoqHx*+`?<;s;Xk2MmGK63kaQAX|0dF0yWEbjcBt<7K6-T+RQ!Bz4 z3GP-D7o}jgB1Ttw4}=V!!FnzC8Oi{{qIa=w_A2Mq26y6C!#6dTP#jS;Reehc$K!e1 z7c%Yu8{)TavEdGw%kGvg+>90b=G1@hAsEKDBK-DmAy%$B7XWf|^cWX`qk;?;n1TPH zRveBY7Chk&$^Z)F$#EfqgSpUyDFRxB;&UGY4a71-lR<+kf@YPji14=}SanCMwuB=C z2yQop=K&i|;S^$F7oMSMvEdn5_!Jc34wztb8-i#d*l1(vD4>7|Vi*AU5PbKu`w-V5 z8rET-COagySeN)ls`rUC*CC*w4DP@asQ4JBp&Pnk8jfLQU3eDg*MPe;f{CIGrg#^Q z;TW>`814X#OEWUDGlL(Jg!N>G8={7}(1<_Sj&bA;<~DxQ;emAm2$QOccfxfeQGNd(LUw`T zT?MX`Z$t=Ufq^ski-m$a_}GsDS&#|YkX!hLFBu}D*=na5BC6RTm>?FMHicLC4zl+# z?b2HF@*5Vi9fMGBd+bc?w<6d!n0gDZJi|^oNLl}J% zGnaKaczqdupO|jD;S|34F$*#p(~&sc_*p@i8#lTldXobCMSu@FDpGbD<~AKDIu`Ib za)Uw$`uL9{xtzPFmtPA>v zahQ%F0)(4)D?VAQ-3dg6(T;+8oQZmn3;B@Kc_~0xg!lLuP?@jkRvcDYhJA#f$v3O_ zPk+yKvA-mYgMxjB;+i1>qG36%XL*wAdaA*BCr*L0JDYBwp`lOWYU3ub7l^GNLV4XS zpi{d>em9Q3dV`1CA%uVoJmD9}d9sh%vUS335kd%1n1Sgbh0|eoI}}a-bF>`-aEBs? zB~H0-B(qi2d)2TZVq2nVo36Q-41D?^%9k+i;EC%&AHbV|pW!%QI;P$EofR7)URx+W z^+?;>M({c-l{k(NydmHj0Hiyz1NpiS*%M~rw;v**zuO+*LBRjxR~!^sJeilmo0~x! zc}*a^Mz*^^nYW`ELS!p~zR!9Z?7Oby>a)z0o9-QuhaMC9wXXyLdvt$>gHWKx_W47ogpyXJLgy@gutm8IN;0OdO`annA^qA zthgN>0zd%rBVY1AfCE^d0+v7u761VV;9+(iAv#yqbL1z0pws={Zjm{F$(Uu7 z0^&nn>(d@6CP4CMpY~_J?cYA`=iVxLqVbIz?=Pa-FJ906{uw-8c&)`kz2)$`>c(-r z=poz!YG3-NU-BUU093&8CqM->pYuW4>=^>>rPE}0f_l5Yn~R_5o&3qm^;Xv0B8DFJ z9YO=BpZ;sV0RVskr2qEeUJ3w0jDZ0F3K~3!Frh*(f)qM@h_J{ch!i2FstD0jw|N{p zdh{sn7!!;N1zjPDGEN+nEUz?VNwEkhm?Zx%(yTa1$<3WSd;0tdG$_IjAc`72iZrQG z1pqK8eOmMb2No43s91o2z|Ax(g#x&8$ZNqKGkcQRh3(@k2KgbN$q2{mzI0{}KCeth(U1_S^WG*B?`p`J8iz2FtAWTH*Fz`k#^EfKVO@!TZ65v&JUC$jkc$^3_`!H_$}A#Jt$H=wCSD6%IeX{F?`qKmGuKgnh_bITV+S0R<6U zb^t*;%~jW3b?N1vUt$IJ*C9FywORjNo-HWad>U@ZVP*Rz#sL7teVAB5$&qN(b5;>V z00|V)W*cr^=_V9!VvT&=RX|i<_%7fLGs6Vo4BdisD4|Hp(A`K&H;AN^=+HxVheNjv z3WAh?NF&{ifFPi>V$I?AKj&PWo3rls&0agcz4m&)=L-$*F5EHg@uQ%qM==T%SNR}b z{*S}}jJcZnIY_uV!&oU4FOLE7>)FWf%tl#-%Mn9ptsQ4~*n+5nqj07O$|0wGD`jBz z#_xv!0Mffvehq!C#2U#bd)q`pj73s1;~%J-nnb+| z>|EA(K_wm83uX4y$X+s$wmk(c7ClLz8;lP}69MEN`3{88+O6!Hq~SGamw1@G8+YD* z^?-}j5z*|tH8L*B<@K*`%Q<#(oIP5c*3a}~s&#Jz7|5~$0DzaxH#TdSsPEYsG$UF` zvPe|;E%Y)BcuO0C9QSCFQojv88O|xH%DHci?zgmyieyx0DSvRSc;)v>5dkW%^2*YF zYx{e)MZb1m+M-l8g&7=@kXJ!4$?nn+EeeS zvu7`KTmLLFUBcVt->zFtqxRS9K}a9wq8SeSI^;zLgD;O4t4%4#RBk;L(A(krX0Pr7 zVt5zVte~|x6|K>s4>@n=?}dLD7FG`hMRn@=r$29b`Hakg_E+X5g$sR5ea%BYua)jJ zJ*ZRP4LSc5Pq_-e|8GaOYJ_xpZOOWnpvpdznRhm{#O_j(QcV9QmX z`djNuxx&MKoUXaBdrZdg}BN9*%RC(=6S3j)dExD;~ZY zv1cimjT6@)P0~oE0sLBO5+81-%I#0?zk+dt{%r?MP>s;>z(@0u%5mC@w9B4@b>y_+ z=Dl}w4B9@*4)|*XVze}h0KG2h)OgNE;9;S#G;T4oah|_t)*LUU#%yZRIhXAc>}{g( zV@D~WZ_*z%>&yxdDk;#ViDHdM5a2NQ6-Qeql}N-QP?AoX3;SFhn`>M zjUn!gtk&DeKyqWg)^*6^xd8*zJ-#c&QUl5#kjug}BfT&tmEo&&f`}-FHGNGNnX5K| zPpNcBq<_gzZ$$N2Gcr2_(KM)XU$5D&T6L)46B~!Y#}sM~D zdf2J!0T5v{gbELkM!PagDW~fO^?t4a5Ai5;omJm(P+`C4O8wgwTqpM~W&K|k$16li zafeTpdqW74h#8GAz+NBSZAvJ|X*_)CJNwqbQJ+NP=TvAVKc&>s@g+7D11>*wkc z5mQSCV*<6XBXy}TyFsGbRyMv0>{G)H;Cpy>=STTWViQQCq(*|>a&M+z5arNI(;Ce9 zkz>-ob~~aQS==O9N0enY%e)FZY0F!jb>S*X4<1u-gsl!u0UhRZaZh>5Zr}Dx@7SVT z-_8a}011xFR-b#~9_vI=t~@0zcehijwfrMuX+WxT@Qt%i&TM;cqR#F?>GU{MB!if8 zl$fuS*Y|YW@XO!`&%`6bMFTfCOIoF~b*>Il6`6>Eo#?hIQx}s|wJ?g$Lf;Ge8x5J{m4n z=`24o|G@8N!dU2*B~HQu;*NdW$2XYP`kUVRGk3sO>Q`rlf7-t#tgAC4UQpHi;M|0u zLPq2^rs8Z0dE#S+vU7KvM3QL_nZ*4+>yB64h-f`p<^HQf-MI&&`O6(JAbqe}6gYEW z^#CpY%(?D)x=}6T%FEr@naVrCqM#Q)Mq|dmRJL5k^W5Bg^`disGImKx`Nc%bldc~` z^IPcgs^7vQ=fzQ?0p0_9zZdP#_lvvIKmS%b9VU$I(tNkR^Z4c8+^_PCU?N1d9wKG~ z@~y=`{7cXqRjL|sf=8TD=slv4#uy>Q;ENm|SU*6{&`QQ+N}9ss_nRkxWRSA+OW>^* zsxSRdD0f_GszhbcREkq~|GXSOIoc3Abb zo;nZOrVA8sk-FZ~Q*##es|4J-LF#J58mR=-8bf7~}#r0;69v+kn3bGM1D5 z*=;|EUthRda|B;cf|P*-I0`x_OeK4qsDXsGP6S1`kj-Ec1_5>rfZTjA(fTA#yvIA# zm~Lv2s@Wu2p@c4-4HoRhWaS0XNQs7vzz2~+R(hoId&posS+E}11VHp7XW!ix#u>Xfh$ z7-AWpU>)me^6v3HbyRwlN240$eq{!WPXdb}_?nVIc+-J%Nl4&HJzq$fh9a{~N$*r6 z>Glxm8>BNp@`u)>6_@z3r+)kr*-B~Gj#h%p0#z5DJmFp3S5rhfIvF|%vO*iC+mPQM z46=d)>1gsseej@54jhFR&B-Ql_Kvt8dJh#jXOdgpLf)K0a%Yot4wpsJ7#+|UpYV=s zraQV$EFZp!sN;h*PtXi3q{E14W4g2Nnv#Zl6}UL%**LI!n4xxmy4VP?mY|qZ9*6c=uZ!HG z<6^L-K6clMJVAlBPQrZTxCqEY;Jjd94$ey7dsa4Me;vd0{LW*)L>_7i<#_XaHm*6Eqrb zrBEV-h0jaeM!ZptouCw-g$641suXrFX$}`Vh>sbrxW1Z1tZd3?_NjisfxsmyenzHh zT%JrAsW1!($B=1DQM9t*0)9Sg?kja|6WWu27rRzC?IF6okghH0C&d^hXXads<`gBP$H)2tYOnBY(wK0pOtFi1hLeQVsqpG;iL6 z)VvRHvIK=BaqnUi4A~}IL)US2fLh&5o1u+JO_vu;j}i4sn04K}0a6SGU02$Rpx<$% zjxfL#Ns)*E9+@Lw0pxzgwLjGIb<84v#5E)aWMkcs-AM=fWOb{bBg{}aWNa_VnI3-3nfk}XoQ84a&naab3;bvytHG?y4LRcaW&z1 zGWvMrwV|IrPAMJrLsNj+6z+H}Au>hurD*NdbWplKd*lFtTM~iqAIW)!jH* zFW8_S(qf<7f4Lr*Xm+Y937VKmGap%=O1@Xs}0#4lENd7Y~w1J@FP%ZLef&wJ=>UzFZmYXU7=#CstI> zjP&Im(!}fatYoI)yM*ERE}4hmHdBP`i1^IJy=LKZv@vPE6r966<&8S+;x8^?$?AyU z^oTaH6%E=6+*^;|gm?S3-F&6sH9dsRRpK0`gI*tzzfiy%gzFZ5&#PbjY)`ZG`q_&~ zg|Nev|~Qv1*J+}ELizUnc37U&qs-i#bLR_uGTAwaW5EBz`^wgVdu7d)DWxgI{Ch&9+ zY1YI9O-T*aDYn+RrDx}GoVldsACh9ZZ8$=DI6D~i^y@2<*cAEVNXXAb94TTZrHZ5) zSrOMysGIy52(dzsgWWrzsB6g^(w$O&8UHap!K>dUiy;9QU4WbsrXYSy-Z_$1mp92& zKYf~tA7O*R-evaVhv)cfOumw@+2A;&U1CV_=R;J>zh1OU)QsRMHan(GLiwyx5;R~0 zvJZ?!S|QxtdI+m-nwx(U+sUZH*`jewQIS9KrsVS&5Upk$Y10Um<)Vmd3c|S4Sx!wH zqh@GgLr!3tj~bJD)`43$MRa%1_t3Wna3qWd`iJ;J*xVPgI}KftErMpGJ!TD}VXqTw zpmnY1YnMbyZ&o(eR_xxddZ{`i{`39w&*As~PN2>wS% z(f?mU3dRVKqW<%vnE3w>9>v202r2{j3;-D`K+z4*)B-f00)`QQX*^()1K8UA2Sx>l z0AZv514b?Xr$yzT10@8Yq7r!B1a!RzM#g~eC;zcgU@{^YFA=FY5rrBNl?@R!H4zgt zk+>w0ODWOg+W+vV)Xzj&heTW3#0(+Ctkvu$tkL# zokY>e9P&nz3jXPee+k!Wl!}bJN&%0mww`KOsT!r4nzD^LKcHU9tHE+tlPOH|dUO)B z#F?}ew6*I6^dCJkydJ&;Lq9*m);q>*>Bh#ECbT9dnkN4nk}|ilx%Q(hu$q=)z$0yk zN8|UbTurQkBdlE>+cqiK&fmA=thW10u-DSI?d<}g41P1&Rfonx7fHfdkEjidl=RZhlobc=)AyjA%a}7!5{HI98u*YCU_pcSH zL`kPaeWLXA|52po30d9`a=3GH{}HYssR9+ke~^?Vaj`z3tgNh(zp~bja1BY-trHql zLhw&{-#7!;n$+7kLW@w#H6+!o72W%ZaIHvv+#?L!9T@T>y0)ao4O1s;2s1M?3-=cm zLW%xkq%H|-W(C{Z+dC74U8&vOD5Ar|!|&FW$F6m!&sxq?de2`DpI==5XrBA|;ODQ= zt>4QBe|CQTJ3A$y2?SdLA^3m%s9Xv{r3j&xKxlhJ7$6Xa!U^kd{=bA2r;A&Of}xZk zKR8qWv%I>z%&iPRrR^R?E^P`KC1tK2w3#Js6O~~_p@=B-t!w(5%JG-z2m}|l###9# zeTdIFoZmq=O;Z2T;fl&hC-1?NU!zk#Rr3ut9}qL%Mo#)Koqf3^NRM>bfxb@gQKANN~`XiyYAfdN|c*DvZPFZ zbB*gK-`-)83$3H9u^b5$A1V5KfpyL;3?(7DZFug|^nSL)NygH_a_~X`~=ZB=AplBN~+Cjng9W%*1JtivC=S z;2sND)$Q_EHMe8#r~j-Y8Pqx(!a;j(yUM9hwcD=T!KRDb4mx_noaMUr&11_|%{{NulUsxM zrczKv`#g`ct21^Vy0^_#TOVD1RNHw) ze!Qr8ji$-cVtSdVdcc0|3qHaZgNmS!P6oK5=o*7`4{rXi)fEPkm1_QZu!BZh785In zH%t5mjv4-W0#&jsalDz`aTzt?A8s8S1twiNtksRyfFJ9$#@*X%dSE6nRTUTa^QZ$| zpP3iU$k*=Svy-QEpwJ|&c)fZ%(Tm_q{!<*ys3UQ!-)ic$dsRb;L7hRtxznND3lBbJ zEBC)~oC1oY1@@;yyp_yJ_m{Ld@OL2T;m0?XBr;y%P$B30>1}!7hJG}MS+VU;9ZpvJ zoB3tm6{gD$&!_eB>!KA2OFMNc;|YCz; z$EQK$eEejPr{T}(sQC9kXA`PIf6r%3p8UNSlKatto_!OicRpZrcWYqi59-bSCO{Qxh)0&lR<^~#GdB_%=%f4ZR)sonJ?wy zOZ8tS4@iC;$DqkdP6@n&Xpk&Ec-dg^f^*@+K8rl_zXjZx6gFj%uQB*b2o7D){q~xL zV%bOMBFq*PqHw)857|i1ZA4m&GvRz!hOE+&Y6DVBs9@Z2aZHk0r%KpFu=*d4iz=HW z-hUI}(8i+2TjEGDd_4=u2s+%cK%w@FgEi9<+T|10FDNyBD<8z-wYG=kQyFJo_p&}y z8ziL^9cNx-D>-x6?~t7H!K|1%o_R3H8gdIEr_km6={(9N8sj;m_E7Oa+nD>zH*yI8 znih;zp^!RDM=G%jwb~{*Z#M?5=#kJwt7{dUiw12W?FxGw8&(g-E2gLh#PXq-`zfgf+kXah zmN16fJ!dy(EH}k>_L4n>{iAkyV}<;$6wN(H$_76VT|}m`733+h_0qFxm|!OY$n;nR zGPWgo-|3}`fPh)H(t7|7BwAsZ56UPPejWR9NxQ6+8&$l{xMfhs-GCn={d$TPdALV& zaZ^*)%7L({c?h=4Ne{KM&mE?)z!2Bo53Rdcutn%ioCk(&d<24sFy$(=KzomkQ)U3w z4k7ov>KA8;t-HDQ&bzdd{EMR#pRkTaS~}ViWma)8C660PX2S?+q-#jLjC37k-Qb%j zv%ix`zBqf#>O-jcdRUTwcPR_(;v2vaOkt;H*KD>?CMR=dcCRG7bx`1|Rd#^6l3QP# z!Y^K4NW$_L2Js+Mh_=4>Fh!WmWw*~cyHNUp3`{7w7yhUJvcg$Y8f@1*`r&r8J7Z@a zSUkuY(j9Xhzcu^z)QDJ11VCIpJPfL6ORZ*_-1?So)$j*WS^5uoiXf3t8d~VX?lq542K%fRL#VuQNWt9g+dAyhQA;h-)e! z;w~91OEIjt|?fC4A zqhaN4Z;}$^yP?IO5u|Y)*1!GBiLZ1LJKp}(+?&Up8;rq_HKL0y+{Pj-ibLZ+=P_FN}iicO$mH}Hk zSL-?T-w_c1<>six$*gAJsr1cc&IM-dV0PjbOjl@$?ESt>yMlHS#tyTHY0E8bSGh*~hm#a7SAwLBS@EkosAB7cJ;p_GMI%iW zE6>m@y>b8IM>R9@FD1juDurkDh339M%s)?@snX&lWrNy6qwdp)Foa)Hc(clT$$KAN@3UjZZ-w+M=P6FiC1S*UkMy27neJ3E~xtp zN63vJM@w2S^Iek{%1Ow^*gX3f z8BCJ9q1?rk2rI{(Io@Qny`P_5@GRwp-#~FnnsPo)nKyeN^-cU!H;z(W` z!$cKHn{cFk-DJ}^@=bh#$7elqBGa&_R8sj&vapyPiS)(~5w!a0-+j_4Q`4pPsbnQl zZxq2gcwt4e3{`bf3RKco>n)M1So2(Qk1CX9HOi_w+lC=4bSPbVAL;0tMdm6kcZD<< ziv3k3ZfutQ!XQ@ab2O#*a~crO3pk1`Hz-@lo#D>yDR9IeGI!(=0-iJjbo(~mb7BpnWHbz)P60*2n!VB>wQdbIvNcs4Gr}-&4 zg-D{@UbEZ#U+(^3$QM`0`W##2q>$*$apzE745T4;Y*u)>h&(rYdGxxF?4Yb;B0iC<7JKTFG@vMm?Cr{QqM;%Jy6@>ODJvg}%pa&Y7Jaz!~w+4$~L z%IBqeELB+KNii)IS=AtKnpbMPc66%F#}dr)NPChCB+Ae=CPLjn(w;+S{2?eA*aAupNQ z#@*T~+uwQ+4&HhRwD`4y@S4aa1d8)FQo@UbB;*yb{;gC2=-}7%t`P1iSCq|HRJVI+ zpG60u7Ac*Nlt#aY)WQOV;ptv)1>>Pw$aboeLJ7<}McjY(6ixuTN(!$$fX3nAo1`uE z7G0S&1@feTv=<5F0BV5;9e9J}QeI~WKuLq%6Betk_bS(z2L^U z*EihZ9>}!&9h~`b#S(w+N5vt3GgV};ccANF9>S2od~QXX?tH!4jMl#RgFJ1m9z{a; zyTTBXWsA15k)EgxsM+D*EtwWh=62x@2zcam9uBTy(chRC#Pg^Bg?R`r97Fmx!Vd3n?Rm?a%!sh6EQ_`QbK!DO)dfklTI5>jPf?(cmCi@>)unuU;;uf~v;tFv+h`DOCr6}GXJ(Z4I4 z!*`__xn>`)9y~&(9~HF3=3CpXK-kwt93; zt^6dH{3TPtwIqs>iT)k~%vMO&f174K>)_4xHP@{N@mo`z+jdo3(8g7fSM({elw!{* zwXKkUnK~%$h(z~(?jYNSpDh1T*`9LPRxe_wSY_1o9MGlM5l{Nu8$T8T+XAz1$&ha9 zhwmti>{#C^BYRZ;&wi{~0;MX@DTHDoK3F)pqUzTyFkbuYLnzvbwfb^Pe}P1Pt-KRu z|9~?6AIj?M6tOJ0QCd`s4I1Y)E4liisCW1A^F67?y@Wect*eV+RQpVuU*SD7h|L+n z1L!aU&|}A|AK-DHijkqa7?rOe{XNv?Znfu|2<53?B4e1ih49gSMK8Eq_rk8sJeA1j zUlzN>sGWOKI|CH78)L}Ju^f)0#S>;!gE@?$9{#Yi-$Qumj`{vgqQ%P&%B5Fh_>&{M z#`!n(8=qO%wvSeBc!PF4KDm#Mf>}^i%&aMYYo1$%ZOhlfZ=e>s61!i0Upd-(sI*?t zb7H^wok)oC8mEJ}!r?+!`F^b||CtubBj$@Mnm zkA43GdcN^Z5rdEhE+Lfui#UDg3tOuU5CYF6-MBuR72I#Xh%I z`rku_o#)+;KVtU_E?Xfxzxw8SMaG-FWL4>jL8U!M$et4*@JnsS;7)3ezwdkTgAeYg=2cRS5OwU zm1DQVq5H}xE||HuB4xTthe)$rLsZS6&iMTurwxb5Jdg6}px#06^E@cZZ3}@TLF~NT2o&UIuU*8`4kSSmCZRyK0{V_N329FVc zzX2BK687lK=I(N&(79ek#U*$XICS;6N|id z_J23d_Sk~r$WykK5He?!MqV;{;ldh}(8jOYy_YMs$K{(=dC6U$56@sR>=nF+xK9*} z#Jt~?etU3(==@GTene09RFSlVBL&Xi5_{JESc!kaH6nW8#SuZRai{n&2dGvWxA8k2 z%H@soQK@r#Cfp01H+*tkZRDfK!=ogI|&UI))jpX|Lw^rAs z#5X8Bsd1)@=5X^Z7i(ekD;IA`BfQa&(tmxXgLoI&@R}XeOs&oGDo?$(9w9btD889s zXp~V`_hvGid%Ip!$c#&UT+`m)pix^)EY48;9kJLjzxr*O*-Xzm!x5uLkZM)4^e7Zx zspkj&Y3CctMke>kFZ{U-BOqC2s_YLhm%-QS!eSpXKX%TdTv>fJ`DtNRt&(ctw2EC% zvx#_zlfneA&$!qROAGgUT7dv-yZO>U*N&_*kMI6J8)>bF=c_^oR%;hu)FSA)T&9m| zY*NtNe6~S1?=Lp~u?qfFh2`oBRcS%c(TsCVdkx_`7w&{3uPoC{Pr_Fk)Mue4FCA+u&Clhsm|(1Ir28+knC+yqSB81E*3~noa+?Oat09!+mqJ&wf3Vc+S}cN zZGTSVtFzqZhAv0Pa`;UEM98cf41-IvF{!?aX$GYUMImPLK{p3w(*C+xnN3apv7(Vp z2-Lyohbi5l*@VgrhLJlP+d2KY?RT$0XS&ueZ8JomH&y5UIIsuO`tVarn^^YD*8Lfbd0!olPJtQ3FVQ>wH z5~}jbo@9?IPme}BS|%RR$ex3ERx|2EZkP&_`S!g)Vb7 z3%DqC8T2XbjydFxBd+r^NZF(AgxS6?%X(j$>W`^7EzZ?MI2iQQHf%`+6X%f#qRd6! zbOG{uH9jsz)hBMfN%X6qRUCu*%-5z;NZ&cBK4YZ0zXvws&;0O|WPYlqcuaU01aG@k zH@x$$j>GW}lLARIgeca4OLNbKFa%Pt9R(=#8{m= zT-?_sK$v{8XUS}zob#$q?9*VPxJ%R$Z7-sD19z9S5yGB-SjfUIs{S>W61ILcsFvlW zVtTj@k~iZpxWkgk-~*aL_m%-T8j75aJZ;`vqc_@ZYOQ!A-~2R)a&vu?&s3kvO{MdR zsn}P=v->??#*ww$9u7@%gs({}n-GwvjSkFJQ_dHjWl%p;%^KZSwcwocA{jCwvU!^i zzMTGXiyv~=b?m8U*-S+RwU6=GS1}IB#n(v}%1+u6lbe{9b{%6dU+ZX+QOfi8mxFlq zP`9KEhFMG3ixR$h53`8ur6K;?T=^rZR=-EI8(N zX$dXTlx`^rzaDNp;5?KlvwQw>w1O#DLKXOC8Fqtt`FJf*1zB`#De$JoYtR zRYv=!POY5mvVgKbGsj6krwR4H)KsBAYy9s`oF#X^6I0c74kVO zi8>Wo@OL|keN!=A^C>3yY6!pF)Xcc!R`FzeSO5J?f{6Qo{)xOK<*Rj=LJMLW;I$FJ?e(Xqb;yDgNCnTXm{`2Rg= zb(Y}(>&oEP3Q$Pob=D_Efpse(vs0Dfh*n?PnM3Gm*uJRK{6)x@^oy?vWH=&zJQ~7F zKoe23p#ed|78P0{%bA7;w+t(#Ot^)9zkR=Q*~lNDjASDsb3p%I8o(fEg#p?l>09Fz zPfil$ToZB%zbCJMIS``!9dG&kmyklEG7=Yl^u_u&t!ejhZQwWB*TSLl@6S29`3)an zU1XDwC0laeYof$s=>h5qIYb!%Mi)N=b<34s1A#qX-8>wQ!4eG&`ZbWpy_7hXm|lOKFLIh zyZ7?t89U@-2jy8TMb6q`Hx3)NITSRj+p$RCk7n;5`!LdbO+#M2JQ=-lRq_O?l3xDE z4{<*`;3EnN3kvFIz3Ae1!exNy%zKh+9E}Y_gq3e3ZBH1KOp|WP^!gya9mnY_MiB`+ z{S1?t`2dM+k3aq(x7|gpMg-R*Lf|npcmSbC1Xm-1VF0KL2BLS}o(zx|R6+uPu#AM# zxkRO=l2``}#(DR?hoYndRxLreGgnE=BOyKl1{>_ssRND;VMrK;h!+5%F;tlMq>C=FnV(QaNa!_+j8eW>V2P>#(Ix%X+2GBPOPKmGcGA8B}1lN?4(3qICuYi>2cv@_U6(vZW{ z*K-y2Wk&8F$Jo9H*~K(0NATKDi%6Rh9JFuGMFLt9!wWMip64pdoXUoR0}mZ^wQ@eb zu+0A1fxV*UXU=UWnHc}OtqYNuAUGs+ls2(8VSytU#IKX+K-KM;T6e+(f2$f|R_$S( zMv9TDIr#R}mXzia4D9uZ@}UB^mOi%eL!7C8r@MY^pguiIFIHjNs;h<`TB za(jUPc+&44uwis(e_3h*G)&<1m#23y7{Gl%Qh9`51Z+1Ge>eHF% z9XS?Vc`hw@>sXc1c#_tP@{T5`9XoTVbO#H$xu*oh&%9*lkLsQg=v5#pqt|o9-kgCM z{DrX%f}zT@OVr9$hq5N2z?vl>^>ggUVP#3ej2t!iX<#^Rd-fxymwKd|d$HS=rO-}n z&R-iXO*-z>Iq5k%3IC{VqHXkpQ(Mpx1`7P7`*TjG4``(}d4(Skqo(wgH91?9w}bRN zm5s{{Ga(L~=+4k1=#x$NS!&g0d?bb$L;^$*HpQER4{!bidja!u4n%XDrhARzG44uP zqpH?iD%#30$wEWjzedl4Oo^)WK`F#iFr)a7gNR47oPvwGYUb8Jj4l#?mxkApJ8gs zv)9o&uSdF)hRdH}Z9mqr6V)mDHV>z+5a zs)S}Q2^f4`wY(Zi|EUdo{}HyKjJ>v+)W_sH$TnUYTF>{{MC?z*;U6V#d{}ON_v0ZJ z@5eL73EVH-IEug&Hf5!|$c4j;*seMF|1iKO4g3^KQI21M-VQ7su$*M4S{WdSA zbGAx4$yhgXhb0UGBUSZ4V%@~IHo~HQ>ZJ^BmeyJ&bn9+wPtm04aP0Paqh@8B4Wbw3 z34(ocU2RAnvynW)L5u^pO7udPrrm|cbR5=Rv&%uNYugLCLF}}i#0J1pHojPfDOqh34=qwWb5Q-(yQwju zeIm{}=wMc~BW|2dpJbIx4?uC4h(C(oK{kf{*nI!HM$s^7Svi@iml;EV4BNv-1ND2!Zu&SsP_06o?^ zvL~X!T!*6on{T^4Tvn7P&XKS|E$#WzFottOkl*uNS3vlw4oqxUFyQ$R2@61oQ_+8Z zU-CE2>ZGiSm+^c8dM~oV(Fxfz0ds7hRaw}K`iF@pXT^p4<>+V4W zuWjn*eQcnOwak5Un5$ooqcO%ElXM_ictEH+sO+~(nmD+W_x{{q!JAWbLR5k0cno z*LohMyxU2AXIp>o)0xdTY@li)a2R0|ZKeYC4~$vygiaOhY&@6hv4ZuoTE6_}is{u5Z^=*3+EhzAQ&E2_=~!wx;{vn%wuI0q-c&C(&x(vBKV$#@_@! zNjy&3Sy}rwIroipz(FwO$>`c~)#WiraNh!TQpa{eY2tB z@efu9u!=g%%exON3@FaLfk2lev{wRf8kr)OtKy?Yvi-u)I|_eD*vdHK8^^YHVeJd= z-c`XmWKODkYR9`AXzeTrS+FE z{_*7!NUoQrwP=O`89oAW-kXQ!z3i(ac(qQQQl6yo@z z{L>0Q)dQCeh4(oRE`8};C6X^#U+TN?X!ekVeM%UvD#KjgAnsqRvhH~LT`-oA{P3#W z7yV>-DgC2sYzYVi6rG6R^xEX?UK}D`0NYCMU#A3KH!oE;!sicu+5x^gFMVBj+^;J{ z*r3yqArTlG@V$#H(gb_-x4hr#t{4vTi0vBUi*}uez9s&(KFb~b;-c^(py3?G_DzXe z&*A2-SK9i!Oe;7m8?oRq*c@YLU<1ht2+GO6@(px14sf-laW1s>OjffMbqE9F+1`@? z`_H9-8?k9O;2_P-WF>2Yoye;v&$vhc}Y3g&LJM8+toIb1?^1%e=WDO(2{pRemJWifRhZ=uq8d}jJ zs@c|FPk0zBeDPE#w6&5D;T9Sh7)t&HdjP`HFpy9Rs--9pBmXxc#g0K6{YOYm=+OQ@ zgp?&cct(wgg6#Duz85_dC8ZUH6vkkPz;J3omyHdgNNP$WJv_cw0YXD*fWvIydcq;W zNP1pj8w@6gRNpnqMMKpj8rL2D2*$6r7@al|ZmCzywL(VE=)e->Vz-11JUcx)`0-?& zBTbDmkcsX?#49O1LUdiw-7lYtZq$HT%+Glt<$P=sQ8jEt4{M33rS8pUyPHo3y}y)Q zHny>BrDvWY=i7&^w_^g%z8&Rnr7CjDb7ICQL15xX5o9{;^d%Sogh21^r@zsop-C_w z>}VQ}s3d)0$c4$gr#9=TUwJvQ#6e8kXg^;6*ZcPR^7|iW-*0AVu!%6>h&5>>aF!gw!QJ51Zh}$X1_C# z^+IeZkVDxFOrH+G(ZWVF&hT0QXO@j$y7&7sC20^K(>t0fGAt=?* z@|gmE&c+SQ4S3m!AKB4RT zf-V@+B4*W9%!-vB#%4G%8~ijQei$?~p&t6M1_dL}*ay*_sUy>3d9tK#H#;_qsF**- zLyPAwvt?`|gOdPd(_REy*H7d!0`}C8 z&wA20M7Wn}F|59s%(?xsS>^TOrC9?lgQr%KdZS7kg^e>qz}n-v#lSPWsJ=8tl#Qk3 zgFa%yC#uFqT({~+b2qPE$%BsT_G6h*DC_y%^4r#wzM753wAL&7e$$J=j~tiG{uf_& z9o5ty{}22!1`M_lqkD|*Mp77^3W`W6-5pY*j?vu>ItJ3{NNGn(h*BaYA_9t{BB0Xy z@%es#|NQ>>z5m=f+qrk=+;i*od_I=S-RVQEACkZ`3NG@^hxs4Sh}J zSJk(~<1H_@yH?AQ?LQ(ro`ma#&OFs=)3Q%!y--zq9_unCEQ#LBp4H=7QacLhwqki0 zY2$x!cesXkVcV&%Jlf%PKou}aalEJd2}_V7K}gsLKl4S^;O^c~>1fJEhSEW~{bN>Cj6S>L1pKC`Q+sSM0wG}65RAGfM>}PJFPmoo4vWF5GfZBpVB`N8j zt~Tp*;ulVq&2$y@g9Da9>g_ z=V{npi5Py75t0B;PO`h?j1@J?3K^SjaDHMlYSPN)M;Z=PJM+hYFuDoyTmm9PH0k=K4p3Fp!s(;QtThl?9UL%UE}%@#wZZsB6?NFsANH5qEjJx4IP zQt@+Fwt8gd_0=?LnZnOzOZyKZtP?*``s2m~^X zfls(oi0|NcB_If6?mo=reY}z?h_0r)t zL)Y%IlpFQcrs5dT!zwJZIZ=(4wC>7~?ls#bR|UUyPNnydjiph@?5TiLole)uEt~9i zfn%=mP!yO0SFoA)s!H6I+y+5LkAdCjylHx9{9<}$>N!8zt|8CzJ0g>kKw`UygB*=b zd`G4LB}OYj41=X0w2J4vOL4!lq8_+oM7T44$8^9rXYTT-ZrBo(LgRBz+=w80j5v~H zeHoW8XvMewG(6&9Y)YAYAwc%iwHw6E0n+978CUU>|)l#1EDN%l1d z{P>Q_@SVbxbvEO0fuH9|B(v!gpu+wul#(c+YbXnMmx*QT#!-kH{!Y@YMZ>L;gWLph z1jEnEQav)ic=Xa(`f!aY&DTo93zHoBEA72qmUhXKC=5tJivm1yDMhD%DCRp*-O5xY zbB)`Il`34zMY6KKX)fGq1N?_g&$C*6HU(0DSJT=6=+FCrNMcnLcbG?Foee@syN*+Fdm-w|Ea@~Y zW|%G~W2aY8%o4cS;b{ee;(5|FkELPg<6q4NlKQV63fz;#WAb3}wakrxNqS33FUpO_ zlnJ(wk*9b=n$*ZFdK*lJfP|(>(BDXs;a~iD_kdSjZlkE}Z{NhTYHu}dAe5IXZaUKR zm4quh3zwki`-jBmSNR*GZdJ{XY^GMY#Caytudlx08lz#tEP3_zeEwn{YmmdKV~|?4 z_K!s%=n4wMXT^lII7$CUigQ7$2O_|tlIO9LkgVA{KXlNmFv)As3i zcx*3!+hZYz?FakFlt28#q9HM;w+#A;(u`i(Bp;!F@J#i^<_xwu3z)n=$+Ks zh8Xbd|5;3)%L+;9LCN4V3MQt@WVYGumUJ+40yz6#JaCcE@(|2=RTre2sYr;`B#;Z- z%~X_#MYaudNa=EV+p11Gsa6fC5{J}=`KmuS8C0zrrrnVFQ$b(68p>R17{L*1;{=(( z8*n)rwjp%|v}Tekkb!XJVQq=wH-as3VB9NS@Cw%;xqQ72K~~37)KU7_h^Ga=l*DCZ zc<25A%5V%7OW|DmbmB3yL8^L;w8RkO>UGtQ;U5yi`~asa1|{F2g8*^L>XP`M7*-ls zmMi|Ht(4>#kB?I-;JOmVubdFaB$ZjqrC!(4t*AT83#NkN^QB+%cp&&#!8~ zsp`ogxr*mDy=#$Ng%Wc!;(2}0m-{tF*EnZbbC%QOVVt;srC`NewEBQBWYCNwjt2Qb zdm6;BP+9T-WwD08!?%TZ{A3{KcJs#M{sZt=JsZoYVapp&*W$rSJl5#tnf|z^Xk{%x zVfbnMdP$J20Sv{r>}-%0V|Pu+&8phXc3b;sNq=6@aMjIY`{~`kq%Fy0cY`yxGlt8t z>o^Km9vy*d=W2GBhcjrbuJ+G&ZfipR+tvO;@2u3FUNp^;;@8q3bY3W;!PKm;@5kqT z)g^E{16M&L<&^Im!FB~c-V^uxN4&!^+xle!*DBVwi~yH*&X8)GUX3reCQ41hmP2oN z)a^PMS_|`^-z4$n$~jF$wsTVu+;sx&Bk?wKLAtjJhP4n?_xEYVmQ57<%iR6lsa2hl z!C!P>S`Xjk&>(>dGOg8fVV1aU=$3vI&)3qu&w=qzu(OsAs^f>U9Sva^axUTZY`58S z;gZO^2I_)b+3sUIwMpGZAKQ71f_1TvMN-yaVF|jRONzpgbcfPVi`@6g_RLq6MG=FD zZ4X+H%#tZof>qYtn}xREWR~0Bl3$4mB0BU`G}c-;^a^N9M9*+Xg&-2>?@>^aE`>rh zMtkW+I~c|71ZImG5NizRiMi7;OZUJGjxii(1N`bBQ36QvD@b;FQNh=9KXN#wno8No zv%H^Lss(9JlV$&At~RPJLN6mZN|zcCW2~oS5cq~y5)+*UHBHo|RD0H-(p*}$hUv}g zyoU=O7CzRFdy+Doh2Y`)RNuDg{bqiZaP?W8H4m z`hyLFMRSJ5o2$imHpB;usalh4WHQescH~6s8A>zx|V!F(n-7)XD{t~vA-nt`iZg(5|Oy9jV>ODM) z9iE(Md}QtQVe8eD_b}#$+Z)^AH(@Ssz2jb{3_sJ~p0*lp!`9DUgLgriKDItMvL&2RZiuqd!f0)4o&7jaGYFOub~tyg^hi8JjK{eT0-1>X}}i__zH;+{3ue zoVn~AU8Z&H?%jahjX_SN^xCuWwcxm)Yj=zQ^jI89b65F}KHJ-+*Fy8t94J%|DZ zIq3s_Z^&|34k}4PkUF|_SB5#+TBzU48W=s}KX|neJlvgfZN_St@uu!pMv!Pxv(6qs zFM?*$jbXtIh>(LsJodMo{e>R|i)6~Nt;+Iz|NVH>SLf*WV3aN!=WiK-ScXE`Ln%2u z@MV9q@K<1WWE9MnCqwxeOL?8Nm_gqv%ik(T9v~lr719h*2my&mgVwDMWXZ{tOqz2d zz>r=!S~_wC-yxZGf`t4hF*RNBnuE8!zx2xd^~U^|y(#EdWoQevSxC2Luo#Wc@@x!`~G^h0GMutMa|Mg5A-Oqaxd54M? z&H91zH^{4&P5tyNo6rgIh(M6~zd^y+0dpw+v#PFCxFyHlfUNL=T);iekl@>ie@t`t zxy55xl(CjCLqLfka-pP->%v1aabfB&$!zcY-ub0Jmf=4CNm2LfJp+sulf<9|=Fc9D zfArJcyGtlp@&V^B2i83bns1d{8?dgq_Y_mxE`)}ZCH@7!8d6ffqL6fO0RsK(mDSxm z^a`h7R4ZS$(w$EMuh0eydZKwu?hRkS40MJi55$1oumI^0`P87`%m3+>j=Ic0Wi4{b zx2>Z;TPAJ8!>9uJZ-O)WZ-(m(hsR#=dC{S-20q}hJ2MqV7VXKf#mb8OQwk09c+q}w zBi!{QJOdMf3E0Ny!~q9C5Dm@YyvkVV2%R*k=DsEaV9??16DFFM^tIw9o9bHygA;a|q7vR+ZE4z5+tGtw(hIi^8b z&-cm^$8mOPmkzO$W$X$i=a7UwwV1BtgD%^oW1T9ch}>%C zE1_~gJ41*zLenGGLAP=xl9yExuy1RU5`Rp3{_hzArxS;h2d59o(Z2T|6FpAVRIOr6 zwZ935ALLeD?=B2DX3YdcZr4509L~}NGsK?U9Qva#&^h+_WZ;^tq7^~3FG?p+MHks~ z`)DNjQTH>K=e6Irs?~IB$khxS|6TPCxm3ia+D@wOt38DVJuY2GzWv?$N{XgblH9DP z{hwT2SR+B0q|ofcB$;`7P4k$I|2Ml&O?%BeS+|c3GKQ}RL!F2DSrw%>-LBUd<-&en zr>G9G-lHqsU47yHQZqPP&)SxY$PqC>VNV3h5XlG}Og?Hlfv2J zE8VM;k(H%<>0zf_-Ao^La!(8_8kl~BxqRhCo^{sq8f{a7v{S(z4!?aUAu;3PzX zJfx6CFZ9%+0~Vr9Mf_c?R5E{c0=imM;J&3tT2NEWjC@{_W?T<>!#Ftrdo)ZYLj>Cc zRAU&b2n@`Z2rdH_SP6(;GT}05M~`P>0BGbpU#E{om1cxtghqZi1$o~2QfVJdSL;DL zsZVEh$Ac_FN1#c+NDF*)wng4Y)kdV$B`#k9(^>!J%mc}%wy?lDn(NiY@2gb}DI3VB z-1m;BwkPg9>7(Q#O0={R_2rBp#LG|K(mk3!IHxEBUY9881wA;uTYT!Rx21Dg_J!Go zq88PLqZ+pD(e`Y9{ zWtM44yL0$|2`MWubCt*?9-D(uA6EEEK__W*jcr|?ezcl3H~2CVL#n)%Z#k}di2DSd zkX0<5^;MPsV%HV2vtUMJ{OV4Xncxo!RVVMI1RmSabpkpz0m>+(n?%G6Br{T(nue+p zypXSTyTah&2N=r%Hw{x6wA|)Od%%a~d*>WsyV&Y|mXXuHwbKxofq{s{1~G;)i(9@w z5Isam%kA2hHBc72F_O+}AQgy<+sX#zdcSGBGeD7XpkMKYJtwP7$+)r8JZ0Opw`rYSQ&W%BYC zo$t|T=TwP2_&!@jQv{45r5zb-%_pm_S0W(F`9u{u%Zzv1Fq5>gt8PtcI7Ea?U2<5d zOsMgI(vf*({~Cg6(JB2y;m4GWuXVNjIps`qcvGS)=?&y6g_!B(j#!D1$xvUr#&i4D zo>75ncKm0@#q5?0)e@XBWt4oqqUil&Z2iZAJ5otCRTmFT){Uq-+Sc(LEPo`E6cOv- z7A#q!XV{r+33nK_qCWnvBF8(Wmnk=nx9X3lP*V6nJo`E(K#FGRMZvq`*A)|g4FM6I zXF4p8R3m$GBW%2#s#@c*B_fPq~ql)hAyEee2MVMA+VO|kKPdo!e z)bhrutyzcZ%ANuO)I57&Wu`$|b zLlVJzkK%MU#h&OtSq3P;0vI&h*W85j^`+V8S~;JDm1dp&EnIvy&M7LYM=DzfvEQ5n z*T!>b+-1n;P7@NZOU_!^0YBs?8-RLxnFRD}6{0O%r6b4nO)fU$mB`Q#T`er@up^~H z(E!vQi49zi0~n^YsI-r>SnM%m*K~~FiL>LoX00XE6k1At!Bd%?xYD)5YUt~~#w*r& zW%*}D5Lb2!y9FGj0)~tlw8zLOvkv0)%%D<7lEXz_yUNMBqpysQdx+)br;5|)D55}_ z#%%?P^ysbK*cm+zW|6e{Z4$(t+7dUrPVpC(!dEmcPKL}9Fi%6tsMy>rYnhEnN#!x_ z*s;V7Vrn(Szun2I&$gZ=HePE&!-A>vlxRi@uWx$G{5!d&D@KTM5i|na>2C+ju0K|) z;C?$lVcnuVPjDY`b7r);)?=$A5*hF0a9%R{nSp|!L``PT??cWJhjGHXv0e8Yw9Qdw z;uARX^71o^WoWBwx@sYISJvl!NEl1DKGTH9JrrnGzk^afi41mE>pH7e4w#=F4bj%J z!M4%))}N0%PYE%8o>h7#Dqg{R6Y`Xkem@b9Nt}0f5|F?GH+5Jt!m8ryAwLpB76CW0C?~QAvK3Ho&qrL=4O?Vs zu~(XEt%H^awFa2T(7>XN1FJpR%M*B@I;mmxT#5B%R^zWwMpOC?rHJ^eK?Hq$89SQy zEbVfi{B3={py(cT#@p`V#Ei7DpG)#71t2u{8C%}4=v*0}tKyZ;agcsL=aRrYmcvNK7q(hPPf7Lk?QF;*uFlI`=i?zi z-+Hx;QLg;HbDt_BRjO;vANOTa;Z3cyum)o%5w5H8|mC zOvC-R*0T%C^%*_|Zo&E%RL8<=v=dpcnsl8gpRTHs#X$Bs0})5vDc_P`T-$CkV_`g{ zk-7S}|MOD7*68{K!VHA+%t&%GkKMj}GCkN=_a&j{y)Z46WEns0?-Wg$a`cQhcV9gt zHbFhJKlMdlF~@CP>mknzNNS$xo%T=Z<%+hVo`dHinvC8i~E=o692dIUFAl*RXujcJtw1e78(+j)9eu|#~ zUmDG%-h`@W2>i-c9Fp_S2G1Szez8>=+el^y-uK+4xe?L#-GR9tR^TnSS+Rh)`W{KDM%C>nZ@lPM5KfXFAVq-5CSn2$^CojOlbw~HPIo9~8hkdI3PZqC5W zI91QIn?78mpRkhlMks@xQa)bq^1X_XDV!5tiVGBYnE9e0iT1O>ax@;2f`h5YxF4De z2|QaFHXoPC78o-Jm!u4`O`V8fVd9{(oC$g(Je>8nTc@e;pd&M3fXA7EGmH~p)-v{=uQq3TA}1pra<`d_C5NwXfIV!0YwkCzhH;g>BRE24HDZQ;lR-pZmOo>L zhcEu*DxR)thWB)a-COpQ=Q@(y1Id8moBSkj-prL!K{q`k3QBE2_+NxOj?p$vjY1c_q` zh$3F#K#t|6oCs=9(q_7N6CsGtmMw0Pyr=ySJ18wkmrRo=L&tc7#$5I|Tei=M)hY%d zQb9Mk&XtOz%DWCl$3gha!@OR428D1J(8rwekwJn~dsq2a2L7 z+2%oYjSUI7Gw;fQ=5b4&KcmK`e3tGZf3@7dU3tx$0_-G3ti}Q2s`PgxSOEr6;Hqq8 ztDaM3ZBy-PWk=>I3g)R(2hv(#p>RA^3ZL{ZGTuEt>5q({8F>x8I9&tF(;J6w>TtSy+OYs>dt!?C(A2*1!JMI3z|lrY z378YI|7)$C`(R9tzdxT^LtD~gpQpu&_iW&9A(Ob?g2=gaK!O$j-R0QDDSAXU~YTkPW1irny2gRq}Iikym8Y3&8tnZ1{ba@YfiWQB*Mc zgXZ}eCfOJBHbu_&`3RkgOd$V=uAg(@11z)3K_EkTsN$d(H3}xi;uFN;+T6l+Wa?eB z5PU0+=WSrfO)#%fhPnJkh{lV+@QrY@Le5mc==}{N_ExU4-~pDxAQx6X*N%4Ye_=tl z&BamSTYll9_z>#%f<{<`WucCRTmWNIq@uP{c#yw*c+^d>mEX-xT#K)30-3Q-k*lE02kMN~+f-tdiwh5ldy0s$ zz{e%F-hX8f|1p+Imy9ioj2&OWJniT`ZN)F694qUEakyn3z#JL!PWTz?{RbY22B=UK z`H0v>;lJw~V*}jV18L)A>>M#vVLP68l9H)e5~v5Mr!g5bIK;GLx}WxygBC7A%ypMP z5B>>1{LYx>bm@mKrZFz1^`M#d7n#Tc-DG~HlM$&oKCxioB!v&qgW&$G}oj5l}%l#~h*&CGeM6q37qV`!xqTx z{$6~=BK{+m$~LBolLMNEp&GXFcL@vgD#U4MQ~MTI1$9;2v-MPD%_+3b5mc?tb*}d5 z=9KH=?2h5;{=|Xjpz2U|vID)dTCKCvU{esdQG`!n0z2P^fhwhcYDOj4y8`C6@Xs37uOnSZ#RfG(bW zbY&0OQvm7H{tb26OX zy!!(qpJUz~RPeBH7gnOFe;%ZYZp4ru%>3YdJ+vD6`S*KCjf4hvKIMpnR^d`{=Tb7Q zs%-Wd#s|El4fJwNA5Xsu$9h?~cv*NrA1e4&cNT)!*+J@AZGEVuvc#@)n86c=xb9WSC_c&RtAubNTNP44CXu7r1JerymC={ zL%&@f|MX7DssV`YuUa-k-*QC{1Gp2fah^xn^~m+{GYdOu8XoHeOQyT0Ph7Y=n#&#E zen2(yeDGStIPmNgOYC?NC`U2{A~2uyIEz<~ZKdN%G_QY$c76|U?+*XgeUnp=c4;@L zi?eoZn{<4FEMq&SfB1Ff;s-TX)l~0mabqET%om?-<{Ot()Y@mw$09TZ2ZS|b+Jn72 zl8aDK)RowOMd2aconN2WS2g=nfO{V9>%)1>-9nSjlJFt(zCiJR^I(6E8f3$k3RQ( z@KfwZUV9;PUc=w`(R9E(=OEFptUamY}F;>dc>i@w; zu3@p+b@GC1Zrfw3Q6=&3Yh%5yX2RCf3dSRQ?(~(K4Jjih2jaJzu~QsZ)7YxXD5&Y# zF6S||MwGn5@l&d!)wWMGKX&Kem;XB5=Y0Ni-sz9GQ}G?fo`-Nd{y12h&)g^h529ce zy(DF)9m!n46iAc1M(iPOlO^wzKJFa5uU6n&S$>qB2!CtDxZEfGb@g*0?FMiAKAH4gVfWO$#meEZ7*xm|K_gXki)LE`;zYTV%<4q) zlh~{V-TygorOXwCA!c(Q|A_ne;PgXYaflAt(Gmv4QpD^9dt>NgDrTAF;ztc2(HU2- z8FE5dEVG>M(-94**eRLlmrPM>S5V2qqoKtqzClViL#O+c=k6&!q!uz{I!fXP0jq}Y z@$P?%s^fLslR#j)%PbryU1LE&H^wzPpF5iN7CuksmP+j-*=7iL!E6w_du4{zv{2lo z;^kgN#}QcllVp!^v-9iKj#cs+F#4j56=zM>KBQ+GVwVBG z4x^5SuJ&V^#_qNm>bjmu6qL`u`!|bl;(iQdwoQ{l`^WXgzvF(UG5xA;FFs{V%J}}A zrF8D1GZ`HmVkex+lmo*JKdX>N!Nb=tE;#qh7dmVSrc}`7z{!u)jzKys9@AOFKX057 zo&!}4&qjHT@Uz#DboUI$-W90NjlXX(cAk*Z^jiSvS^?m-EV)eUYsM><%{{7*z$r%B zRFZ8ox}_R(V zueoTl;^8$tkEegH84smLT2a21Oj^4v8@#ecX9ZwZ>978dqq}+n?K+{y0Q3#DxhjD8SNE|Xmu46^_!Iif#3}MIa;Rs^EWqXRcMng#NO3>Z)sHfoHkDv2 zs$h~8GVnD*6hjQt71q(mLyr|3EnZmfO{vqFUyrjajJcji(6$P7W)W}GlX%=5k^?S> zX`)9Hin7(O8gdH+9gb#37)evse|FeqV^pW5jE!mB(&q_Ol}2Ty(**;q*Aj`{=-+vp zUYp1u0VA$k`w?TO!*WGm)DL`rr_gO^|M9HVaKOx}3xmf)!?clXBai}_u`7tHTl_uDpdAfgwLngv}9Ax8!dbV5}9<^t~9c>T=ls#2;Ozy zEKtr^sG%&`t4-&PH9n*qS(Vkz0${?nYxC@p+YxId_Ui|_3;_!(rAWNZ%-W1q4soUbW1_GIukyHW=i+Y4GSw&Ql;rVNa;L9RpL{Fs;y7hYjd6&J`#sj zd(n8%FQt*k3)|%{tLn7)H%+o4Qmw?rybD%Oa+0vE`Nn=?H+ODHT+{G1pw00%lMjqfwjc3&e-ANf|Ei_v?uU{0U6H>Zl?m*| z&c-g*qXOCEZsDxGLKZVUeS|U|G+GPX&&AzfkusQ)fULZeHMVJNr8{lx3Ik*M3tkof zQQwrKG2xk?Sn!i6mh>yv7aZ#bztFx@WRmc0g(SHD+MaE4aWtV+G`u+3fZuJ+M;^19 z379(0H%Wy#waDdr{S#cBY6>4xQ!g!sdZ?V{kF5WZ$^4{f{rx;?&spwcd-6y(WzTaH zZy!5=YTp~gBLj4Ax0e_H>;1XE_!h&OJDzPSQJ6YTyzBO59gDvw!bo5A9sf+ zSekpHN3-ev(vFAU<@rCXPN@v*&CE@XLmh>BS)*S+3B7C`8iJ4&P3{E^%LesF6+-|W` ze0~joP1F79YfTmTGo)m$0@d5uVs~$4QSUreM&cZ9TOO?Mrw3|WpD*EP>mDrpwpi|3 zxqUEUeZj_PmpK)i^HUKi&6(?vsk=x?xY^8$!J5}yo=>bhBDo;w@ITX`Z=WICHG_XG z-?=Zc=-);a^y7yu_R6#Tbn(hDzn|Rj^~GE6SD;1d{M@5X6(8^Q@u zU0GVK_}dDeJz)qO0)G#wX%N3YcTnJJ|Jl*Qn;v-RB+T#eQj%T8ZiNH+?eMRlQF`)% zoAWi~-v|2~UOHvubRvVScMpuD)y#|gb8^GIev5ml-`efJH_>n*W7_{L+4+xT1@^HZ z{z~UP^Is9G&maEl`k`cE`%7TpiR)!~vidX*&1XYnMT=@?8Ac_%! zg zQg(vysLD_#BB>LnDHS~9a%=p${>F+k#2Hw{T|eSbrH3pL;csy;2N76~<3sD(sDl>_ zZDBsE`U&#RRI>n$r51&a3}p<4W|00Nk^vm!nBZgRa$ex)@-;TP7RfjOh09VB92wC7 zG#8pv*A~puJBUKJPps z+=i(hZwFPrH-!|^vStvEXf9e z;G75s#JB>tSHizeuD#Br4q}$=0Mtf?;T?v?K#QU)3u;6SSOPS)08I`dt~L->OU%2% zKuTUO%5~Y1Lr+tNX|cP=Q2sHbFhCZ-E6Dw+8MfXdERisi9r|}gaDrAoAd}4(0_nxE z;$8N;w2G39Bc^*cc_Jh7ek}#!WC2) zRbrH4aIot2TzWE^S6M7ZY%;ZhIYO+NVMwJIM`#SP@S$#r9}@O%54Lpq-5Lf1LP1kq z@uU%RPclmk03F28%oXQ_Inq>Tb@Pru@OG+qd27b@A~a#{v(bs&t2 z8b}17MN9OxS|x-)SZ6WC1OVMRrq40Ydg}-+Iu3trggXa8T^YfH)1*Rf3wWvxe5wcz zpD2;2AP*iZP(Kboqb`ivPxz3N?gHe=I6<#d16>#zw0yS6afbdJTNAmLTv1uITO&>}wIU zJvpeGvEFi;Qrftj8(kuqjhiJVcd~;AN*ZoOK3QjnjElgq^}=5}YcjplXC2EzmMCLn zC@1Rb|J;yA%j>NGffsfmzJrw=WNt@AN{;1q($i=slPx1c4*Mr)rA?qB!cJo?V~I z%NU10{A#wbmw*lghaqX{jx%P7=m>Vkw|nrV^;QjW_+7SV>ST!;UL}#sj09X2Luu%{ zz-;<#ipg(?39UN8<#hM}l(8EjMlI*EPRa?dYocRFi*YPwQK1wmZRu}MetDAPkVK$E zw{i)XVMjA@hJR|ARmvB;;y5^xLz69+*eW$;O9GDw^LX+JpoQyqAv`EQ zj6Rd?JAJ)q+1ouBoocg3Nk<10IFXp#wf>m?4}3qVta=ZwqgMD4U?3oKmH)v8*J}rM zir*38MmDuxT?IB-wajrW8r}?kMd=;Wk88%@jV9UXxu@piQ0F5A4`=0;5yehzHC;@S z=V_OjUKYbi@u`>i27wEWd(we|K~id@D_|e#+a~rJ3`?MmYMrW>4pqncTF1tplkoLP zgqM_p2-YAcYzB27Mvx42$xM23IcbnAX++W zGCJeJvfxKF18PMSgGky7M_Srl=T%~9w&yTiBzRU!i4pyR!HH%G*VXAmyXKP?`K`y# ztBu1phhq#eF`d!J4qhmFJbaupxZa;OPODTpEM@re5NaW#g6~+54=ANrl|iAkvLlT< zV!PwayKuvXJ;vXYmWpfq2O8krX&Za6B5LTY45d1Ce&7+@sq~dn3B|pm_#+>im&@fg zjx_#b5xq#H3yuV<86R!8gAa<9ZF^JoyzcQmt}==!&zT;79^FsRM+;M*7+lMDqJwk4)Fg27FzY1c~Yp*~a^k>Ey-4#|2o0}PE4 zXQ2V~apE3qnd}Yu)C~M{`zslI7d??93NmXhXOjheuKfHVw9|Gx$J=R^TXODuTwHZ; zHp^opgVvT5AbF%f}FY z>zBj)XH}!6^QQ2Hde*|?>=YIlFbAvSH7%8lDe6EH+KzKv>*t-!-Zu!(G+8n?+cE4Z zKRq9ZhTM4{^COzvHbQg?E#$R;ZCZSAMT5>T; z8>ww;HOa2+MMNg0cy<-|i7u5-EpzF0kj2JT(IkFU$*B;%>@kB;+mtm;t@PBiK{#q> zCTn7}R_`U{S37p~HLZT1pWqLMtRkPhOH$}XPE7iJXb&A()#{l*(r)ZNdS@=D3XHrr zTU+aR9QqoXs}jD1d+vv%=CWV=%^fImA3~j+{w@pJAo=ms%!LS}X`K8>_PCgg?EeL! zXhEEy#7h_opb`M6;Q+N10A&PV>Hrfnz=Q-ic>yj-03{Cy2m*p?fP_9EDFrCp1XNT3 zRXae_1<=t2bbSG%5Wp-7Ft-3K;{m%Yz{M4CDF?i3fuP_^Qy7RE_z#VWO8^q)fz%Zs zD+kE=0_1-Oic9~~qpGR_LJKf70=#|$EGzXVlN)G>DF^Z0Yla3$4K*__P z{ucp8T#8Xll2B%i9acENPA$%%O3TT~$wkG5G(_-0_)svlOBqVYl3ADq5TVl-A&^8Z zNTPRG#m-5WM3kf}yEIf1IS|?`OM>1nHGsEI6+9du{pNJ$&W=qRZ zl4YOtE#BN)=cL<1GS+f{O$5n~uiS1@&febsu5a4ic|`|S2d70P=QnCDE-tPrfU8fU z+pxB~Ai*;nu#ko)>TwA8|-@`SN#h(X50 z$b7s6p5kXo39?@j!kv>ZNGbBaQVidv;7Dnxw9A#H{yTetlw%3}uliIdR9JZbR{eV>R#sVA`SdoaR;;%6BdN{_sJkH5cmJn8wS|x_v8NZ3FFNm&dU|?#w@H1zz(6W# z#B$_vjmeEogaVh|(-fXG_v=6JX5IyjFY&;o_q2ON zx+I@|hqPRhPX}5D2MN80IYWnshkr82|5i-?ZJhc0k#y9vbUg6k7x0L^D>rl`4SIy`O{8+-it#on+RCAYx|9ac=fUf;q?M2Y%25EA- zH_;t?DdWjHn%B6G4?b0uJKUCh5cT){N<%7%l~Y6g*4AYEmFsjD_kaA}V=N4JDC;|! z{r>y=i;q|PA9WvW{o{G?=g$k?M-*#`>yKaymzj^X;&7fAMDqeiJTw0NdIGJn$gS{2 zr`o(k-jt-g1g>h&jW_}9JA5j=dlKrJJZgmhQe) znMHf=^JcEOzUWrohcsn@RPkVs%>vDzYy!D9&g1m?t_3?)`9>G_o)*}5u%oi>M2UKo zL5jU<@;no|W^z=!cRU=tKpeFtD<8bR7W>lHmp-;R-x0A_!A5SD=7IuiD5}sSVU0`}+7vN4IDFgHe)LL%mChw@`hhf45i~&H3l=&xw@cyM$pD zpWWs$A!wt+4VZiyN>=f-5eKC%g<7X5i;tKLd~12lt?3ME)S8e=&5_!^dg!XMi*xbG z>r~2{lpDSZ5pSaZVDYp6jN^1%`26DFIn%&4VsGH|qEy0s;^77rar7cAQS*YW@@Df2 z2nQJ+4Cay;nvgp9rhUC%r}@gSt19$DOfPo#J9r+YQFo1|nEKTwdmGEQObb;*28TId zhttE?cIgIQVWWMeE+iOR3F`2kcShQ$G+GKHSAR6jjx9&e=k6R0Wi+kfDz7Quq8V

    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 zDgl)J0UDbBW?-fSvt+1dnSyz|$Mx)dmO+1H>)^68;C@$I$v zboBtHX8yx>?j8W|U)J)&@qVhO-MXXNWvIMvI0oTD#+6_ zDC+J{a|i0j88rRm|B-i4pkSESVA#$Op)nC*0f=}opZ?D0LW3bdBZtR?Bg2Bh!a@T4 z$L_Eq9YAcENL~r1P{jH)cPOi>fe1h# ziZJjUOr;E_(J-OWu%qYD`;>PWO!1k}m6^T(n30&7`2|?*30dpF>|$~pSh}AA50{`m zw-*V&q`UyvfA)?*7`Y&>wV<|+keGx}6IhrMARI?2iZ1%OBr>R^zIaI+3d@7&iqotQt0wOg2(pnC&6jliYKkH+p{zekh-MYFKz4*?yTjeBHYE58u%MgT2Av zi2spyvT(rp6ySOl@INrP%@jNV1~2>u?{0A77VQN&ZkC2K#;qz}z5io( z$VWkE-gj2xIp&!p{`wBKzyC^%=KlT330S2zC+rLO`sld%ovqG@sg3u1cPMT3AR&wI zYDPK%D~UPB_vUm-h$V=`zvbvew)qiE^0D4}e|9wcZT*Aa-|umMa!|*Cr19nT$*UF) zty4JQ_2Zp}EEwY8+g6CY%OO$F`}iVR2n;*bhBq>W^>zfpIbMGFWle)==-x0~el&iD zwV5Mn=ub0a9M{i_QJ^sIP7J3}X?_?xYH8tDrkiNy#St1e<4ntd>P#do4{u; zNkaOUVG0NAGboK-{5U^D(t~#Y$DmsC?sqNyUsM@}uEzzbCXI4Gep=4e#t6@;4dw%81bO}#=PWZ$9Hv~Nf#S8a_KQ0Id1a3@1GCm9JwJ6--9i~t+1de4LDA8`A5{!a z=9(xX&2-H^5E01k2nzud2;Ayg1X9jv=aPs@{IYl)4@byI%Vd%5#)n+h3c@%?P zyhxhRl%;17*OKPR6!+86%WHL_=FXw9-7E+c@bu}<}b)ks#Ao$c<0|i#` zku_8`F+>_pjc!Cb$Dn#>`U+L0Y0OajN=~W@_?t(GiaK#Q!Z4(IZYn&Pal}LV;Sfa1 zX0K-GRR)`Gxg}V-N%`YW1S!5NCAM++-4=njdR$QT&imuWq%iv4cZT}Gt0>BilASC5 zi;od_AJlpx*J=lMGtDkkK?(hMl9!{Y(V=7YA1QA_mmW1(#uAB9h;?6pjX&s#GCz~>9_VfaF$3fX z6=*;gK6zA*O#+S~=+~f`wshE8zMqL(=8-IU6dUV~r%GWDNoFZ)_)-d{D}LTd{S`aA zc)SPct2yCd7dIzn6@2w8KAz=big-&x2ut=?3^E=*QD(7FhbGE9-NC_~zs^ay$oOCI za7TpDD-s^)i{$XPyD0nGFGM5ql`>u~$11^WCaop4?-W=qVfW15^wnp|0Bch>2S_lp^PgNUI5cG!lmpX-73cU2!CH!luv7D4^ z=Y3Hb{+SRkDse#}@zGEk-%594pJ|dFoQJkJPHnim@VU*ethGG@xZtlVPTo%GrQK(q zYVwSVNaKOuEBQ8z?oI25wn**Z902 zhq7YIG5kv28(9XECOUJ&eAQ%!Y1Yr8u`R=86B*PnggE{sd@&SiB}AO?%Yo%mfi?{V zCTV3dUud;_bCR&{=ppHBLt?En5>m@c&ames5 zh^=~nK@w5N&Ts-FVu>DYVZ=fPo8owQwGV1>`N~q!SF$xx+y>mn#&#xzzH%*9{mNvd z>C9(G@WI`&bJ0L0v&Tfe@EUe;q#nDkVrR5`Q4pf;qOG#i7EwC#@un@w4##_$t3!pu zIQB)I{2oSp=`ADhf?P(L>KsiDyl~!K+z+!z!~wP|O+yzi z`|qa*1G-o}L#WZ84JTWFMcnn&J_v+3yB1P04qSw@Tr9bdwlf44jD4qsRBR zN!YFKymaSvJes+7uo<4Oh^FOTXHPItH$ZgN>zaUSWtsI+c)Ueu7!r*5&T~5fSyk3Z zlA~r8&;-W~Vlxixcop~!a}z#R88cs9A^8kv0o74-i_XS?KC_(5?8B{{7@}h^{2jj{ z^V$xc~!A%wu7`LB)4lduhJXw8~>C-cBdzgP=)knv*=G)jXApa zFm2MI$)>Nr2%@qUaz64-BuPx!c7Cp-t~J!pKZyPFQC>`F$lhcAXa6rP0SEuuYru_v zUmfe&I!%bTr1|Z(o8&J_^H4JcwE4;L&1CH;`KJ&-+?9U=uL%Um6hUNA|awu zfhlr-@z>-4#xUcS)ZZ>ui$u3gj)MAPi-yg;xwDI4zT-|*j{=#OBgmKw@Zr;goAqne zEIAyXoSS@eM}v`f}G&u=ZAt0TFm|JUO>qCe+7C%J{4X~f*%IE{Ju zFKD=n7cm15&Hj4%gq8SlTX~-rn_o0~cL4(~sl3hRbhB9{n$n#z9>uJ7oiO?l8vrUr z(oQBEqIhA>pb`NS8lAQ)A=N1Ksvm{{vrrEEkC-B_%7gnzi`-`bey2y8xzk@d=1Sp|+f7#&CX z{Z0=;xb|is4{FWu>ax(91R0qR2E}-I!k9`rM|h7Pc$RwxFUWY|fWsZ&G&mVB^zbl3 ztml0jrR7pALrSYzCDTGI>q4%my^*6l;sGv-8X?~gMc3+FJ{k=ki_BPtoMO4qIZK_3 zenhTIh;S65SCu$>>`RN|d!%TGA4{M~uQk&N` zOlKy;ZJsA`DawnNLxS+o#zWVAVpe*>oX?z7z`V;!oGYpzQoM1NLmypPtB@-zOb43N z6bQqbo^EF$8a2 z<>VzShQaXgO`T0<{Ar$V?S6gF<3FDwZ;5FpZ3&xV0pDn)3dZ9?^%921b$(qG%BS)D z8X3neEAuL@V_+@T5p5NuE6teh(2J$xPU|Yoi+YgvZKyOp+T41IEg`DdS|>VU`nx7d zxE-FQ*4<9R8dM@xX;KQ7HiPW{N7y~K*ZD^8qMn(tjV5Vq&Y-bv+qP||Ng6h61V0&$Lck71M8HPZ`ugk@m`B@MO@F<}_GNF@le!WY<>#@5*Hrap%lQ5K5{M z7n+dl{>-4_RDrZ;C0B)hkf?Yz@U7;1?v=g%A_OTcm2q#7b8GhSSAx|&d*@a{Y=ED) zSzbj{&4En|MDY#(uOx`gEInUDyU)htIrs55_jowk<1Y!@B+m*{=TXd@zMvO z7Mwg#+u4m+xx{$v+G&U?OE`P)6Y>lVV=y6;JB2XfRx( z7wB1W(KDpDaMd{fQVDpUpaqsP`=&eJhH#?dm5>R0a|W0AfO(3MdrD^dvoLx}3a+#) zQVT2~|5Bx5v{-y0f#s1+5KFGhgctT!RHo-E5bz``PB97h4pkba#??^`u)hg1Qei@w z0o8OP*2|#%@+mgymuLTi{)~wjhFwZ(UCdQbI)YI)M$J5Q@1jYn`fZOYJHN1Ll$I5O zyFm%jaY>0(C)|wu+izoLMjCai((>_E>he*FW}WcOC`?l&$#5X3d5-FGRPbIkNPP~* zMW}T4Nd8dUTIoGoxsg{DCGI z*3GQcQOKfk6BIM+*0a;s%M;Wqon~>g)hqDUEBe-tO4e)JHs}#F7|=K9yb5soHVCve znCLcG_%^D&HYjIQnP)UQMK`+eHaWjGy0aR9=_%>~E*9K=a3AHta z@-~D=H~F151)etBv^9UHuZ?VDxPB>Jr~NCj+MGDn62sd<`swNTwqTVtr^+^G@wOHa zROi|@=jpbZowoc%Y>TIFE{<-ET5UCWZ7pwWX*zA|ux+hYi*Wo zlhbYQLF}0HZ3ktv8^X8G5wr~IwgqLh8QXrcJFoN$h>e@89erc%vl$%;h@Gnhoyn)w zzsp*d2s+ky+s?;2Kee3;S(;t?uKl*ogN&{k-_8?)?#H&S-Px|V*4ELscI35oSfp-@ zw-&f@I)t^-+t=>qQ%KP*$VFXfbx`-lYddmJ4-rEH$y*op8XfK#t(!~_zzNFr3RZhM zMXnn*_0!BG>;W;LvC8#v#PspB_tD2xU7dF0XZ9?fqDdyerW?Wgq4i>s^`+#(r-S+_ z9E3EW@;0&;Jq+VK`nP;kV|-KwX_TF8RLX9oP!FxPd^B|n zu9t7TUvGR+Z#+c_eyDwX+;4njZG8G{e3Wov{tWK(%k%SX5GiJ?#jk%=ZnUz!8>nZxAHlOmIJzM>rMou9=Z7Yj0IM!HmOc$<4Vv0!m^@yc z0?UnkhUB63r{MC&HjyT)kpQ9zFz^-dv2Vjc3{%LAt=RrEUphuU_e?Km(+_;3Fcn?T zeBHj~@F^fzNwgtrz*I1pZzdw9i}8Jyr2`gQe$KSKgNl&?Eq02Ye@1_8#OMtM{5A*E zJ_SYCrw}u*T0ZZwHZ2@WEb2dou|5fN-B+PU3pX*3xz^`3j%Hxr_rb7W>i>_rV@w=* zULmWM>aE8xw(AUO5dd1G(OdMGSm1D((uwT}W?b4ns|>1`tvXwjh?x!3pSC8PiPfKN zKU+%9TRQsrFS6sG7yq)}`h4d4vYGuds{c~r`*McuWvl>sntoIFQ#j*4K~EH!drdhvYX;>`6ao zN#A6x4^*sF*l!-4uRZdwbjA+uo-fdLtX(l~L3D0HX0M%9tfEYAy(4eko^N7jFTK2P zE&klZ5ZES(+x}9yeV?_3Fu7g7y$zP%p=VlUbl84d-#U!l+0x%S__~7_x681x6Cb<9 zPJ~Zqu){RD3o}{w+kQvmeK!hyZ>3`wqI@wuqnAKn7ZPG0hH+n&X-7tY68&R`|07FK zuW!w}k9%z<1N}f)?_jZGpQ`s0=-I^*K-0GyQ{{t|wLidOIW*Ke^z1yaiz9Uq*pYIW zw>z8lAD;^Z>kZlXZz~v}ar+;+oXt_A>;@81=^N}AZnXc>8zTKWk`!}@RdcMdcAWWk z9AIz^b+H@zu_GGS)rB+eNs<&S{!!*gK-qod6JO@y$~}|rZ+M3Hr~s0)^Bh& ziFD?7HWE5P(TsxII=QZMv3}V;L&3jPQHl01U~+NeEam-73;mph>1cU!>H}#Sf`3|a z@)SOJ`lxey1LXpi?Bcp&_wxi#oHc?!agM~ew;y+jQ*lZ5b$b0{TaD>5NBGj2>HLxD zFuZb(mGM|x;M{h61oZVfsQswz;}S0CDs5x$4CRLO@<`eKgvc36O@9t1@Ji`?mZ}Sb zX7dmeta$v@kboF`fIM}@9=Kqdy--Vp&ezp#%zsR7c)RlXv&=ruu-(Ut*)N~G2KL<1 zZr_z(oJpWENOhgcVGJHgId$S2+fm~8k@(lm&bP|7SFWzlHuU#O zF!;sL@nymBWl8a3SMi~Zcy*un!+z@3Z}Uwo@MBByZN2Kl8vK5m{n5h=zD0ds{g2&2 zu&cA&5)S)hcg&WiKiM60N`(TgnNM~H5z#`f`KPI5C^4!J7I%V~G=N&LRPPH0rEnUV zcB3DB-GO{2xBJE3vlG=|&X-UFLK$|8kvt@Sr0d`W^AtLvc(N?Idb*(k?7D}&|Ja=@ zUGg6(QaE|bb($3he5{9xsXtkMU)9`6&?(d--}0>SI$5hGss9O~)LXhT&aq*9Fdx?X zvpe)7wssnq%{HW1YGrG<>-@4ED?TWc{eo`?D=^ih3&h!Kdm2U1xzS50wstOx#aD!c5z->wBxzl{C;3xkNKX$B!MQ30>+ z;%OMUc&2G=qsi}O;7a?wY3&Ehf;~wnIgWOJ6uQFFUQ)`x=A9JI2T!wKungS0$+jB5 z4>EMK6HPNrAGo`J`*w0!X3h-YndisjyjT`Vmp|<0C8hdUeY)%5^!>CnTOZr=5ULm3 z>Xc6W({gIo>$Bn(4PKjyF%Dk)k~FG}^BVny<@ttNfpOcK(}2~TmVJkei=LkguTI%d z54r-~4Iyp3n9G!F*MsOyYgfJ0;Ecm+woAY3to4mIm)Sla!V4fv(~9e~DDKzGHhpIQ zhozD7HHUxNhWt(wUk=+HS3-;1Jvx*mUp{KW@UYFMp`3}oZ7xq0;bP)htPd(U}J{r|@VDYKW+(&_M3PQ?MNwb0yhSXT@(?D>J z^jIsP791I&dQb%5ESa;J<^~yl4%3B{0zl#ezQ2Rf*nTvwS>Pr`^&7XM0(q<~*gnU6 zTM@;v!2ALb&(MT?qB*Gz$&~zGpXJRwZUf=3gt#;QhQb%9I{I%P(()$&jHy6>5Rl1n zPe+vYD@cGJ42Qzdt&JTNL6B|rN1~)FN)fX)adI(*z;7$#R1{?B;Fxalf2p`YwcJcR zydcTl19?9WmExhbzciS$0O<=1#Ev6z%=F(7z-BjFZ)G8*(Pz1gqPPso0b2EZAHFEL z`ro3AHf+45^Evy_z>j%hSz(*0QXTbz?M!N2L@9uULrRInI;C0<{sL5m5fH0ENUiH| zv1>y$$I{*Q(#czfVNJL&%Ls;z=+7*#Q4ct|qn+M>z83gfMGY!r-_DZ%b$Rkc2sW3} z-kP6YXRfHRzC_*LR+Lv~u`#uwM*ZB*T32^z!=s_)-?@XS?4+uI3Bd=6gL70{tfbsR zT1u?8LA}l-!V`9x{dxrra(L%D8R6jWp`j0`6-nOU&21?p7yXbf`skrACH<_~&n{M!DJ%494Nqzq@>$^XzgGKC^Pwg*V z;ORGC@~|`UCY{_-mjRw+9+i^vHeuwAY1lEh$z-6@;0Ep`WM8jNe1kP<&t<5~+WCGm zQ#n=I-=j|(Zi83u*U?es-4LK(d8lBCqc}=EDj*F2l5k51t5<0!Tn4*3J?uJx8;J+H z+i0XUrZOpq(2R6QYtROzJk6SLG+V}PylAhRa-y7>$&)*0@%(T0_L^nG23xnQLVoxq zLnR+<`h-rWQ~Kk$r4+6zDclm^k2DDoj__q%+oC?BYusXZziJ|ys6mv5-x7^aXf8wH z>L)?Rfn-~2-^04gFC-<1Ee)*nvJK5VY{FAR$c%*`#`_$~^#mxj)(*68)++R`;~J=K z3sy`VC5U>AP-5MXEehl?SW2pvbv`Tem5nvnjCR^p_j76bkc7SKdRDl<=k{UlS}NpK z1iRYQIu)8)jqNXtQ1>u*NxZ;4$N^4a)Py*L{Y>5G6^<&`uM;S!Tz&D#LBZ5|y9CTn zz1}NM(V>JpyFVVwc+ZamPuX_~EuVY%4K4#-S7*qHQ~C?}Pm=@RcIZFZ9Ydy@=)U$H zcFUxR#jiKHkngR0m)v84*>`^A{Igz%oL-y6 zOm}^4`d32vyrYQmPtEa;*D=)1yAdCcLuLLqP-J`^q=L@lIr`U`kF9%bfu3{m0aqzq zZNd3jw-fQ9gmBbD7vI1a&%>}pSGj5Y9x}u>eh~qO1d@`x)5cD&^`T!Ya64|o9p86U zv)6_>Zw?nbuictMzwVO^@oe;qgwYc7Rno9{M^V+T)&1JGXfG*LItaTw&dgx^cyT|%OsQpA1o4aW;MIKbUJ0Jz9%!KJE z1ehq0m@}Io-^jo$X1uK9!i?j+lyaigT79dgT~t`noM)|E^P+4FqU`meRo#8gqHF^7 zB9v==&wWB7X9%L~+&pGtQAd46uYK5d!jG%{l5anx%G;!odXd${(&lJF=jGaI>E4TEP{Db-ULIHNHX8&)Fz}=c>!qro_;Xh%3mC>k>&G^{nHt6N zgG{7zV`NWx8uV92|N0Fw>dAF0{W7|EC$_x4Ah_t z!!TWy^hsHInCw1<3;-?Y&4%i+l)sNqa%&!sGM{3bm1$RmNmWE~Z*BZujJN!*luC8t zS*$xpj&J*p{Nje`$^_=xhvD`ve-}$0fIRJ^E4$k-t47g2yo|8KK)tg@x$!o&(67{_ z%A(&YH!e55$EQ3wE-{5wy39vOB0Kd}Y{rcu2tHDt-9;9KU&_CJnjuCCy+T=)OcqmJ z@vC_ZwiTc_y#T4Y4(DA&;dS~+OG&1;W^bhsfl`G^TzNRM7GXGurWr_wJo|%C1#D|3 zh}^(VGNAnRT$tXx5AvH5lrJ3jsw~En3TR@6yJH#`dtNwv29Hurj8gcZpajBKRtR}s zPj7CVeLl6Im$R^ht6@S6d0ytO#frd-gytTiw-TR#Mx_VNyCYisc z>DLAClwN;#OcQdse*BtoXKLT?)qE;=eZ@6{-WMa)hrpu9TFT<{ zKN^;z+?PW67Xtq+g-~h*Hv9ujXiA=ImZ@pQ*)PS3Ys({R|M$&lfZ}Tj!1!DDze2IdX?g)lh=SJDvGexv@Immz*QD-mlNAGV z&HNIr>#}W(YxMKFTk`55DZ|`o zHjJWKe~^)1Vbmsusv$?-QazEKmv6oz=(^$UdKy@}{HhBR7pe7i{NzsISZo{Xfbl|Y zd&9+e5;!$rQ$8dUHhePm(9!j_+C?$G`s{C@u#R}|UNp_8@o}#e*=&F@toY7X$&^Kb zL}LJ5&;#>k^vu6T?y(Y$7c_1|g`>Z?%b0PURRHr|`Ke#QpOb@;hK*xSKh<w zcjGH$gBUym*8Gjmd*RXYt(|`3VAD>#JAS%GVdBA^TluvJ_6hxTb^cD-o*q-c$F4LT zJ%@k@IUg5=m{Ezio_IhN=|>G&+!m&aA$M-`|g)Lk4B{TZsxrQ~j)C0$&gHVHm#D`(1>Y(7gLZs;xXPASZ3Ra#6$E)N) zP)Y!3K|APeIQ*4rTl28j-gwdxuDzgtQd(qFj$_dN|uQyz+FoV+q;< ziQ*_!bIEQoz+T@gTtFzKfarXf<6LvlUIW@T#t0Iu9%R4eVXtlk+1qGO!E`=yA-_=> zNpb`^f#Psf6fOj3KfvM8ws7vIu6-pQO#%m{8{}}c0IjP9MONZ)dSQ5WaGE7?8l?rn z<8^TrcOd|}ydBiq3y7js3X`LOTrs#juZ(AXI)6gB+`d?T5xB^~iNZDtRrRvhMGI#N zI_b(rr3eaxAa;^ExZ=qd*9yCYxzIieH5;@wAxGr+6@Il5Zp!stAMR2!H}qGy z`Tp6J(AfnV>IJ&z88|hPL@VqG<-2Y3cU)9QDVj^lpd-)CGloM@^Q&es! zVc@xu)wQV-jKda;`PQuwoP*9UN6sb(F5*Ezmy`0Z5FXCkh$F}&4H$PTlN}XU^B@OS zLAPCnyLi1j#Nu#mJa-jlcU8fA?ObSONp}rLcNI-{&3Jc>i2v9f)#7`dDOdhWSMw`Z zq04(yyt^#}C?-u8WpvMWTxFbv{#%Lq8W zw1+3AJCnd$Q%BulugfPUCri$=C!yOboX@_hYmO!l(;<)kIgcwM#}f-X-gr1}!)t?_ zhpi14g(iE&!*SYbm!qOvR`5f_(=`||=Qcoc4^q;xl?k3g3+id(O#9bGufX-Q)OA#Z z^A~1MF~LXmiCEerNM$Z)sa#0pLubz%IDh8nEsv*A;`1;`k9i9#sR%fwq31;l&*V$D z6!6I&hXJq4W!#Xr3+Gid>H3PgxOX*^avRMRq+l7sbS$3B{MT zm!~@cPw7pO(4QT3oIVX*o{gTT2~`W2`u5Zj7x6jIt(=}^InHODwr+KHQcB@yP0;E= zP}4Z)f5C^ZL~r2w*w14>DhMz;+qhhJMcN;UKp<0Y^)qiE2A|XA?C6?&_&;`M zEwYB9H;G1-M~_=51U`gQf`R6*%f5Ufw|nEAml0G?u1Ev|5=*z)R0_c3M(yN|cD_WV zct_4=j!veC7}-yX<*q-xNUoR;|wR?`(zbBa=bA3-86h=m*o_ zO1qx8v$01Xjk&C=hUF>g-Si!*Jzf6bA+1_{^AViW!O>ZS(o zENlQ+mQ|nY{jrhbd0hRjgY!qWtF7J$=KBh6c4{xx3=fGTj6y}uY^C$vl_ugG zFM{=#>+-FrBxXkga`(t%^2&Jr*Xu~&Cm>n1l)e3glH9QC5G?}fbAL{?;th@OW#knO zZ?zc$uWW>GUNW(WACB$9-VH0p4FMOC#I-w4K?s~RRGNU6BJqbSZO;4gNV&HohD>%x zVoq1!1c~rJ><-^XkZHUy0_|s}6rbDdrzG7md4lZ8(LbdmyIs^2b(NM0Gm*lpo+w(M z5wc(VyNXPP*Q9{6u@PTgTLKcy{xe>Ij$#to7>AdO6f*cniw3a~87VEw^O^QS`_ z&q^9GSt;M#p6rpPfZ#YS%bo(`-Y_jfLWia}i|plZ5ef1%L~^J%=VIDUVe1Sur&6oF z?z%YwT}Aea4}EEdL3m=GeWB63Yly&IQ8h~d#cEk93gvcAS?Le@`kBervO3Z~BMa#W zKpFcA{P#O8GwnubyShIv^o*^?wPs9KQK?F$LY#g^LT#-uy7m$k3&Z+aa{^^{SE6%?Vy)r^p=eD?GM z2LIhZWdb@C(<>FKDnG@*n7euNc-WeEIob#h~S-K>UX@0^JTN5ANE z&O!d@`fj+&+Hes#JN)y9RUcjh&3`e7OwW5Mx+t>{_{pFqA=YH4o&mGy&ZphNU2N}N z!k#bGTl;bSy-44-uKG~9=C48kGJljKAS9LJJWq-c1Dn>nk~&?kDg&{)5qa;f`0l1} zjY1LWDFky@22i{F)k??%xvw_knUoQ^!~z5E_~yGqo`ymN1s<>ard*%yR|NyNa4N3A zA}B|%sP8CxSDl>=Oo2DNBp=C^eCG|!!Aqx~mucOhVC8C9L9d>7xX5p?WYwW3!UU%r z!`%>Z)Bfno#AtL{Jph+#9wpmcSkvKLpauni0WFlEwpe)Q97N9Kl#M`d1^MYmM^f4S zLE=B^h_CO4!SvfewMuA%#;^HNS{DbfK@-Ei34&QTC57*S>!V1#7ALV&1Xv}A+|^w9 zAh_ita`$#ImZHHjR+GIa;0>|fILE7%lOksyb#Z*Zb|hmj5Qh>9B@y_87G7e6du=7e zUke-N@3w})$tp>zz!I7`o{vYW(n%7qjoak~q!#t=R}Z*JgdI2gJe&3t8dZZ6H2t>U z45|kaQg4#6`-1`K+!E?4vnfTPh2lB@F>Ifi)LgrLBu>^)#s`cPtacKXI`|1#{JE6j z@?k1MOSTCSA@8`;bxb1o_z8`mMl811-2>U9Rj%s!4cAdC>L zJ{N|cM#L2m7ED$D2ZjGggqTh_Lc%Q%htf)%8Uac;j~U~nIx(db9scg`6f~7RgpBHF zNJ_0+Ar}@v&J;iB_pBQ@f2^#Fc?YsO5$A7Y4>Nf9wJj7vKh znsgmFpX{mZC%;|L1VsU4GV4jYN53pXyD?f2`EWOD@kWha=8s}&S}rZk4vKT=v@vYBnvGd7rD zwrZ^Fn1di=mRdX(yZXY*yaf|ipyzUXP&Q887#WP~kbkvbezODnD(j((U#NuR`ke=o z>KdcRd)ZLNRa-L?nwmxxLFNc)7kK5xi1vf8DxY-16y)CV1L}H91+xecE65mgIk7J%+XoW5vc;HBPO~oRbbhRB4IKGIE=brq*eLtG_ z5TCuTxXWQ%KW0c&mhzQu{5$K;7S9uTCY&g`p%J6UtKC*ilxHqF_ zU%^X1m!8ku`0j-gzYP!VocEjcD>G4On8EIpZ!k{VTL$Gm|td+I`96#!XC+2 zz5I(Ox-SoWKhZ~hU2YP%uM&hUyM<7pzb7Y7YUe;47epm9ohWZ>B%fhcuAw# zl8e20Gbku<(}mjEEH7ZXiz+8%E$GP#MPz$kXOFh@%XiVx!21v}XSctJ=P?c0{iy1N zu-VINoAf=PkGx>Pkwc!B0bR3gWVvti|^g&XQGt z1<5Nq37B-Nq9CHa2A{)dYxQ{Z-+4G%b8r1W$h~0VRqL%KccYDpIN0wSIXR7qdB9ug!lBu8c+Cq?L=Z=2{Cf8a&>AECEPk8`mN zNauu&F!B&9TMXfS{@5{Q;#j1=Z|9(E7$e;neS{ka$Nbsw--gtQpq9-8^(z%xO0Apt=E*_Xj>@>KoL z5I5tA4yZBXOLH%~9a*k_9|)=Ur6-R-XM+I4gat;Pl4ol~yZ?(`FC!q71rHKL7=o1$ zhVcu6C?~m_~w>q!h|H0$_oV)=)&~L1*#`z9C{&YM1<_{tnBqvSV$9!aD-8UGIuq|iYOW>#6X4iJ4Fr`dyIEfk~;bB2YF7j z;hG1O-}KB}91iR(!if0#Tn~zzKlWToEo|s4eM&7ocEoMJQ#u9|+hu23s(ivd2Yg4N z0^_1qKMtf*Eqn(H$X%#dI;o|&EDe5yaEnZpOq*O zQ76k3IciyWqZ~^EA$@$T%|>ZliKu=Bh+%*Z6gn+LJ!m~@4P!NE-FPhMl`NATjAC0<46uMo;}Rn$rp*SH07cE zZDXBjVpas)Eehz@X*3tK5T&oD$zPz>{&xHq!-7`mz&hPJv6D{SjItW%RN~j?lytMw z(v#>>lQObD)i!3;_@%-6A)FMaf&!sL$%T&i^qCU$Iw#hD5>KeTDGRbsVhv830%+?v z=$jP=v^VIo0?ccRz-6rmCCw^jX`QD&0=8{Le?^4MoH>db9riPJ=-W_ex*lv}zT5WF zK`CU@ix*M2#BEkp+A7h*{x4JMS`IoGboR4n?#PE z5YLVa(^HZCgU#ioM%D8L(@Rm+c_s5}BH*FZ@fC$;|Kohu<8mg|@kOTUt+(p6lNk&I zi5yiuyHxG?Tt3NMbOA4bj|>pDjsV0fNYN|s#U zbA;Euf)jOoGpUA&WT$3dX$l1Ntj6+W!c20)`HT;vUgB(CLDyXY7afm$=y4pya3wEs zL!I%JO4%OgxvE090pYhbZiPT^xu?%ipLL4%mZ$Pks zLdgYL*}{77Sy{+MZ^&g`NK{?ObzLYFZy+^UsZDQAPn=IfYAK^@UnXmg25qx{fX+>X z$@*QG(fY{yYw^8Y&U&9KNN+4YIVEk{)iXB!KLZ5@7~GuI&#=`ITrBGZwAD|-AbC&4v07+iBX zS;u@>$uC)le0WPE>pH4(i$+~cf663SR>haZ#uLgWGRG#&%+7XMCo1WBUCFx6QT?^< z43aY#f34^1Fp$OR?yFG`e_N%5YrSM>y%d4#d8(UaAiHGo9gXFkL=(G=Ap3dkopcvF zo8ldN9V`0nDI_(JO$|~R*Zo`W%>!$V5`nuix%;cal?vOvay$q=9yq^wE1J~ibWwZyqX=54ifuzhsM6ywzfW!Wh{R5x1Q=<-X5o81FslDrA ztNUQp$5EgC;Dq>SQODsx@Mx>)c6{J0>DOrQ$w7em=z7VaMeHKP#?h?fX=CW=aC+-O z&FZLn?rGU*Cwt}9)#Q5k&25aTi@p#P;j zpO+O&lmQEp9Sf2Y1Z15LDe@F+?Q1KJ_u+C21qr=Mg7^TSUe<(OjF?~$O}nI$a9>j} zXucPNA-Fo4Pm;lxQ3=TICd#z*_PH{%60lMhk{+w4=@!`O*pIgtGS1x7GX!K$=8;YS zvevhVfPe$M;T_ceNw^U7{Xh}GdkZ9hc28t5Uy>#FsL`-Z(h10X)k=s3Ihf=p)%>1! z%Gbfn$Na=683Vx_<|i@?LC+31k_2RC=c7D(x9taZA&M~7ixKScHD+)Fu!6fh`&dD} z%T3^p@w9f()obq|u*%ktQAmL9On7am_rMVfTdDJqH*7KVUD8RUF24li#GmBr&lu*< z6vI#V>s^w;pRpd|8ds2V54h?Xw(8kNh{Q`h+$y!?n?5GY7}QBJAM!60YC;r}POEhb zQ{YZDWd2jtx$Tf}>g{amIW7*{^X;#N^b?5@X0!@ziSNJFnb> zl5FFhX&nCe?kB0@Qr4$b$m#VC>u`%^$iI!0CqU7; zAw}8=4JJv}lN0yeTSR8w&N#;PXXpFB5u=6E2H^qZ#{Tw==s1&xUe;^o_zQ#4e#ewG zy@xm4zJBt;v%Q|C0zOP{OY8NF6>zI-odoieBOfRhA#dC{1Bz;wW83JH{A84uc4aMEl#UtZ+>7XO~mYnyFOU zAP7?q6Kr}bixU+#C(E4}V=d3Kz9xsp6W(r%$^*Upvx#qe4U>xT$ZSvXUdwpDetLF3 zaaM+Q-;Tq!d}JQqI!FWo|D)Vlo-#Fx>*E-56R@aXhK0c`Z|ePVBV3#0)~nlrgSrt#TWP+>qpT6P*w&Fcd}@ zwumLw{#>Eba%xeEt7zf6l`R#VWtKjM4+-P6&y!_{l<_jvFMAlkp_i$N4oUJHJ#(ss z^;dO*QsbS1`I>L%Ff2*y0R+O_UdP@YjiDHW@-0;wX)GaJJp|NrHh-Z9y1vH!B{zne zzp!O}B^q`b{Vp4a``bA2#9&gOSK9S&I0O%sS{NzHExh)Zj@*{<0PFHW%5Z{*C0We1 zIgY&&@$}a{@gh8yFSIbf^Q_6l)3x@j`Z#+f$v2)jq@3xr(rBD*z^J%s!tYcE@sEtS zL53K6KAYaKUyCYI|Cq&eO%hi$^)yCEJg4IY!|;cu(SCmuM2Z&d1;a3oJ!2f#mJ zF!qZO>}-cU8j-=8ea6TJ&>Y-t zQ~HT$Jj`P5fVD>guPsGu9gJzL-5X6M7FEWQXZhVId5?ltd!(elSH5GJP=2r*VL~Yn zN2YF%Mp|1>gFeLp$rERWe@-Zufgp@;-yL^uWEF>6Zqy?;NSlk_+y1xGf3azs+jN zni66DmSX57vQb9r?!TeT!jc&BqfH0`{NLz~^8X9nfguLKBLfha0Z5ntOd2cZ=WQBw!RaRuUk2NI&{)_=0PIpQE-MnQ zD3|~NLEkjWF?<%I z`4^^$77&ISt25yzx5G&c!4*Klm6gqn!p+kJ{seaf-ob*+U?Eem@E0dhQBg6U-{R=v z;^|Z}bO4!LdYKOJf7Z??v||sJCk$7tW>Cgb{)BbZ^n%senbf+$pT3UfJ6OvTtWBD( zJ;q3h+?L^_~Fx`uh5T=KM+g1DRI?Kfpo1z#%i>FgZY&gYqY_^XcnEM@Pqy z$HZ~mCQ>FQssR%968{&mle`4Z%*@QC$<5UR{80ku=jWG~msePVE9on%%pvNW!S(g^ zP1b;BUvTpWxMdLBb^vZ?ZvU)a#oqsX9hUw9XTV50_*2>WBz9&lz;kLz^YilyzJR3& z{MFUf|Dc^4@Yc}(QFcyvPfj1fXJ=;@QGicq=kgtV6$gLqUUz*7zKLkRy}i8?xVua2 zyN?Cj=Zrp9&p-EWyiDxAuAjZ#e7v9C{fF*ofx-4*u+RUXJ2_x*E-|>A7hEd?Zqft~ z2ZBez;H_rx!|DGIx>G|IBqPm$-(PY~G86|T7(z(nvNsSzB^#o~omeQIhHu;{W?lQg z(493}R};k_f|M}WGHm8EaiXMDvCZ|ysuBMO-LYJV8BHh?sWL1k!`4M-5UGQo!BK1b zS-$W;=#Fd(qjZz`^~-$QW08JvAjIvt?fj)tQN%Hw!MK+5R(FWKh=8@1tw~85vA`rl zgUjwzuISkMSxdFqq`q>odIvuB@m!(!Shl<`rEPrE)PVy*+x|sDS8y8&(U->SmEk0M zRNIzEt-~pKSx13&&b$4ky66D;j@I*2p(tFi;73-w`}xsa;K2od(bM($ZMvYM;D_%0 z)2*esVV9rhYZwGgP7nk}$!0Jd%2G}sqQqlPD6$9*X(&3?C%PjO#regIpi}a9@E4Rv zl5h$WtDUHdV7#43%*GO<@W+%RA}^W+FS0<^PB>F9hQSgO%i9*K-2~hn8j5(~$tUsz zX|m<~crgjr?FvQ8zjT--Ef1*1h7Qdl| zZzujYx?>RhJJP`7cTq;z_rHH42+2y1ME^Is<87YXT%m3B=NA?1VW$3t*I$uX5xUas z#3GoIVjGU%$EBxVZD>uZdch}3CHV_FCn8Dyk)`FKwI`=mm8CDoKQqb1Y%B6M=&Y*J z8RdO5m}mP3@}ibnqr>+=G)ytaghoZsjX zU#OOCzkBJe`DS1~xYQ(I+V*ev%fBNq5Q;-pIfMKljnO3uOYY4s@fSJXoHBK|(IfhD zYkBFKwmWT0o7#Dj`|(5hSR=o_a->4xB8Y}T;}W3OMt$v~G#;8HP~3yU)q+bFBg}Y0 zcN5d%Q<0_wi!r)maOU?9kY~*EsbB=yu}V!F{k~=&1aOi5Sb&V`7@55wE4U?Dth{FL zWR~U|UiaFJ^$-@l1k3;alA$KjR6|C+%F%FzL0=`Tu%!IC>$1b(8i;XL9wA46)`MRL z@XbaMf4-P=ucB7yMSYc6of%og`nn!9Ukwfo-vH{bk8J6J%kO$I^%QDv zEy1ZJ{4BM^mLuETJ?ce20r~@}^F=26 z0VljmZZy;Yg2C{#=w5mKe$YbqVvJVPw@ZTb9gPp;+E{1Ya6WYjo;N{02_BRQF6IUJa##oD*d~aIBpR4Fw@A&c$v6hk2G6TR}M-;6>Se z@trr7eJrA&cnm$3(i;S78Vu7@I0vtm@g@;Gcgb;{^V7|a^;qLA(frV>u7Vhru?(S~E z0|A1C0Kwhe-5r9vy9Zkz@80Ls`T7@3)l5yz^wam%a8%Z!XuioMGVbW=SSPgfMQwJt z?%vQb{d?4OTy)Zo1tlDWbKHE5P-5611jldkFEuG;Pc>fS3f4o{o z+yz?J#*o@P%Iq_FEqcrs3S4jX&T>f=ctB5%BHoV{oo8gm*=q#*$SrLt{*fCLmm0H1 z?gbNJi?!0f;83T0_>pUshy5+ep2 zr!SK=DbgMt|I?bZEHl+*Y?xe%ToSIYLhP!b_A=s`_SR*b#l!d(p}eaM|P@`_o4q}C9jEj=ks!hwzsc( z90N~aa)mSK1H#PYVH4)y+jb_o*fn$9pqsW?WU9aFR^17%oRuMV+vocg-9%Oxt`hSX zY;;md0LrDPf><|yIgJ{c*0>U&u^of)?sWbdj0QD#$f6;q`i?L%Py zxvp2kUT&?zU8YUD^C8zj{i>WEK2F+cSS_LV10!KdW4xZ{o?UB*=cVSERm1a!!gmF5 z!U{rdOZSxue+|M9>dtXod+-+pd)tmINv2IbgVU@-$ORe-Gu_e9H+kE>rY#6G19a`> zs^c*f;zjaht?nfyJIaI>SFqHX0(EbBGh;Luv~Hg;KZ!QmMP8WY<)K;)w2?URw1%l$ za7KD8a{+vAhtbne@vgK!8)}6QLIp%U%DHBjR}g+4g{6OKSW?*%@BTH6!EE1J4BBp=r^-vik_7Y{3a%h~B+y{l*atId6WVD^ zohZ6E7LGN)3blA171uVbA;DA3zz+p`2{sd2_J83qUl%?%bfrLpZ=|Fow4S&%FC)XM zo5K=0)SX}qDRDxJ@6{~SbY=RvflUbZ*!~xI;_@26uam@92Q%@IS| z32G$hJ^hEj4EG_852vRzs)xKu1Cm!`u=r4N2n^3qq@d0p1?nnuK0Af*Bg_an}T zeahjNRIy!T+vorbneW3FU9 z;sk-}bbpq!h4@G#k870SLIftcwQ$h=XL~kQn>U~>$u&7#JDJmK3`cqri&yDR#hnVX zx0LJdfpg#|_j0KNg}P4wjM?Jff_*cgwLWK*=Fo5b-!bdG8de zMMqp=h`m$&@&ApfUM3fYfvtvNp+?~)LG>qxGp=by1jR)~hFa8i??>3|pAA!V#na4H z$Sf@BEE=jTNm)FBW7_E_#&T_&shEuS;(Y8K$*dVfZLlr6kB7rJoN8M>rRO)GHzFHw zrC7o?MQ4ZKmXJnK?N>Q_$<=U9p_oBBN6sHAo&XxeYzUQaUw&oy7K$$tD1#Oyut@son|#YN$I9I@OI!Gu zH+56~o`&x7Rq^VSFK5!F^Oc@pWvvrdZM{_aw^i0l6z*r1BdC-%fvO))ozG-bu3xIZ zs#Ls;SvKhUQn*ze^VK|#u_3ot172&O*J=*NsxNf2RzhnK)+%AkE8o;>&|hmW+iKfS zYq0sNDH!Xh+G~gztI5~uFy!hG_3B88>IwDgIl+E)^o+I4?e)Cob=-Ef?_*V8%Ig@* zm2OsR1+p6aPV0I7>V=USIMy22%j;R>8fC}pAzvGS{0-u3jfVWSy6ue;evQ|ejjDc4 z)<})|S@oJkO>%m*=14V`V)=|O}=Jn#?}6Gt$zG1k!P(TdX?J@?N_qxg0HQ$axLZKZB6A>eR}O(Yjr*4?f!Nh zzsoyj+gk^bIv3kJX6HK6UON`}JEvmX6~Swr%lsWHS*`I|9a~6UHh$1jdF`Tku%a_< zt$yvOyz@xA1BWE#hb;YvH2iycv%5Qx+NEY-4bBH8 zk^3m+2Ya%H{U(N4-iFl$hPhn_L&32FDB10y=Yz@H@KLOzsrsX7{-bF?gxKKG?Df%% ziqTx+v0ojd`TAqA+wiIa2ocV(k=gyx`t;x8I;z%3WGc{&$onO;;nbX4Kg!!sUB*i* z#zS7m#4yKW@{1dQ=veY2bRD0#Q1|GkN>n>BaXz6VKcT5V90#1NUmu6>g>Lchb0D5* z@0i@I7(jxUDixSA1WrW7P2!tQT)7Mz_6d1`1BVH+hnUWL>HMevbxcdH zeEXBumy7X0gJo6M<&C!`XOsm?g=Jx;xnPH7!}n!Vl%?>C zrR2)xsoRCv9P-f4g&&hkkqUqP1^=e!Os3^5e@9tO5L~W{Th1|94Io*KSzmFj>@Ut) zEHzkhsGO^hU#*HK{pqk)p0k#uuxeSkQr5Y4GP@Sj`FGG@ZCGwS%whdGWIbwfJy&qG zFMh3-X>F!*sV06S5iGdm*13#Avc8D?p-WS+0E2Y0+D7r`cjzKLy z`$_MRIc!AdtT&7fC;|r@CuZkS_Fzr+MdJ2L^>=9vcSJ}xUM{xD6tnE?2hQJy#1(eL zs?hbAr%bZPFfZ2R4G)}L4bM5K=_!h<8=9B!;Ufj_`|o!qqx}}HPqujC=(a@Q{(SzO~g|v+f&&n zr)gCr8JCA+Bp3_wBTE%Weun6kQ^VD$XGMXhE6JxiLYt=(Ll&DS!4-s^QwQC-c_Zgko^o@+>G(mIpobb%;dCc)#+%}IScdV7V0jk|Diy__*%k&fWW1Y z!KIMm$^G1g+wZeup(}^YKIY2Z1=Q__z>BBAImXM&>%fKa+{1ODO%TbBQPow0|22N@ zH6qI%gcCg!+NE0O=0(mHR`)4J(0btJc2Ly`8rj)>*A*Et}%Ku+p9A);;Kx0eC;O z?z-3feM_Ts-GK5i$n+qg@Zh0xCmZyjPj)M5bkEB2cy;-}XYwGBcxRdTAmw!9l6X&A z_2}OF=$QC8ez~a#-u3K$G-i2n3wm@gdi2@4C3HFqLVFG{I&~I)(nUKnGrEWkVn`tS z2N0g{C%gP*@J}P;$)x%zGw~*y0YtZ{m6 z3wo`aeytXM%~5*#IrWkczHKFY8QFSmM|&&!^)}W0He7v&moP|>u-C})20Qhp^6U90 z`05-AxGRA%zqIv?$@V^?_r8h-+^>F42}0-l7(TDsPfdLKg37l0>%%4aWk%@@1r=Qf zSAo(yT0TiurszCIJZT#P@IUAdn~6jm0T*OT%WT0QHJOC!IWJ~Gk4(Y>@(w<`X_^QM zohYZy{Qp6B{?1!XeisV+AYQF6QAro3BE=yPkEe=CfwVBi_n7@j&iC_n{ad}=R5h6j zE_K-FS@Tb{A5|7>OBZ@Avi*<>49!(D?cQrsi{6DO3ni!;b?c+cMJCD7QVdnc*sP*5 zR=0&Y?p${I6F<3}4*hwZcBb{k>_`-RolcSi$&|kBThCIg)LKjzG3m{L&sJMK=DRxA zye>AoBi4ol^`9uEQVUQo*Vq5K9orK)Wnb2|4V|s1_-%aL$W4^^6ro=Pa`2DL%W6n5 zxkoy?Ki?co|MJc?_i3BE$!bV6JW2+XzlU&P%W6&#{gcG|8>#EGPF>e>BS zsd_*LrR>s3gR3InUO%QnT*JV8H;3C;e$o%z>}ZLvck>txVsW4ACG#@rHmfqj@65r z4X%?CJO-xy9!~~pof=*SwkJQDH+)+sdGx$r-!(NoA2!mA{H~auw|y`ky-c(rHkU_& zVH7ir!zcn*Od~lQz1LOyJ6a~91(68$V!miH^BAT|EbpWbLz)* z#Mi?dyQNn1B;m(@miZPFI)}fL6$y?0q<{8*i(=DOTMI%^Khd4E-iRv2>TCZ#X4IE zzO+15ZN6MKUVZ;3;3EZoUG2yF@csKcsN4TC>uEFa@lLAi8|si<`85fCRh^QA&}44 zej@wZ=*ijxjJoKNEa4lFplxwhQ}S=B)TB7WbX^?zY%w}-WJHP2$+d+>&IxYrB4}69ZRhmck<<%4kV`z$Ak#WmXlhfU z82S(i=36Lw|NWCHs4-ea@=#9w0wN>?X=NIg_&Y`bme^M*1m3#T*m6{8+~WcLI?UJ{ z;vz!5lQ9v~>2$XR5PbvdFlv%(`nRkph%Vk?XfXVI%E&??TkPnhwks-B>^>CFVU0A5 zd`dd$cTxJYj8TF9_FJ0MSz_nfC%kJl&&x4y$gz74&*oT;Sn^3bApv;U#4M0itLvdlGP9 z)+9I(B{9N9iun(0lmf=oU_aDL#4c=+r6XKN0ZIr71^i?kw`cb0t<5b;ESEJk% zr&OJ!OvXhUIVfDC!jvfz+qER*=bXCj{4AX!&#B5M$WurjU#@Rt)AXI&1vPT}Oje~= zORR@8ie1BQrHErn;+x8E6btL&R8G|d&r~oa!nG~dzpt|mxQ~|eHX;^oD}eS*oZoOX zmIf$e+KI>_32q(d#AY?Jlem?9(H@j0c(21lhPO$G5fzfO1havmv)^kC?BWsgMu=Uv z0R<8lHY8^)n}{lP*daZX!@=LILTmE|elUI4oKYlJO>J#Kap2kETPB~H29$UH!O|Gr zxV+s5VD<#VvIfHvkGQ6}b6xmIWa-T)B>2v# zKA#yxqUoej;FY5skx4T56O~WpH9Su2&ZMn($IFIOtbzVuqAVT&_1d1E>sk}r4%qvU z%H~V)woS&tTgSEpAJ3Q#L43q(#t+VAj>|gV|6tZ0QH8ygbY`8=QzWmKHLUx_KVh=T z{&!e3x0sP)W{KF8yjy?jI)^-=~Tp?<4_ljsH`1D5FHZocl~fyvUymg$}M}x z{uo5JKnG(zfb?On&9ap?h)C=9Q%v4)Qz%o_l=Lq4i=Z`{6Exu#xksr&fUSD*3!*Zt zOFl-W4T;oCzZ$7)v5$PRO0n*8JM%-Cpu+yWCgD=`F6ZxvO6#w&)XN=~kEH?cHkw4Q zEB(3ZwR(aMqG4@gm^z;Io$u#*Qm?BkMch;7C{`FotJE8h-1WWh`_6EBn+K@rjW(4R z%G17U7$#orUhj^^Vt$+5MLgh!^PDSPIlt}e%jRwkrpo{YOzj58n~}b@t18s z>cvQk6^Hph2Y##81di2;+g7T@-OG&xuY8a4rj}<>UH!#~&jA9YdIkEV!vIC zEicPo1tjO*!>bzs-tztWHyow{TSu2Z6V+LN!@Q*UHyxjA3f_*sZ233d2we=b`0w&L zy{_5?{ae^uKc8`U_vZt%+)hIY-&5)Q+k#R$?QMp7P%sL(quYF~?KXUzwhDM~=)B$g z^+G(}EVS}-E8tk|oUvR6+if7St{to&FSMrt^0j9{o}~2 z`Xh0KFDkaZ45ssATCm1)AO7q{Jthqz1RHW*Yav7 zFuW&-WS?;3S0z)>1G(RXCf*3Y(1||Kz0D|E)+>UeFA8Pf183iim)c7-(2HLvdd%B< zi`8q!5l8aI4R~Y6$L>Qi@1ZpBMm`sTvlmT7>VwJ#(cKFYr3y1F^s!_MGIBPOa`us@ z_K~gkQJjNNk;T9)?)``hJ>1#R(4S#pkuZGcU@kKdnYtJP1&AKl2eY34xqUYalLDh9 z*nO^p_P$@(TVv35(535) zE2Kjg;=qPwY?!Oe?qP$9#8M8x;VIoh%Q0p;Tk4RG5xM~c5Bb5M)pix?;Yjn504SEF z@ARygED;l*^Le6ZJ|)V0wTaN9N#Rlj0htRO~zYS~!e zaE`omoEXP=pA2Mybfy1rNq9~&@}Kg#vLacz#``Z-wsJYXaxJNHmHFds=5j4Sh7N3o zcx;MP)h}tTUwZo}YQrUe0_9d9#s*x+IO1e72gYi#TW~}qFd)lo3Cruoe)oxw{S=>Q zDM5{fE-*fow(^&+0*(dTjbW^ocR@yV@0RycQ(&x2Oo=N@FOUY==R>A67_Lj{0MY)q z=YyAA^NZw1*Y^9e@q@P;hSS4k66G62-E$G)|LoXP<_Juz3Md|a4Ne38))SW=ZkU{( zkWD@x$0(a32FcXvOJ5M@WYGsB^-!R<43`rt-R{eea8A(qNuTvGH;)ZIhNHdm0^m!6 zkwl>2dL%a82VuB~bmOG;)RpHarU4qw^vKh%`!eVD0|>Dr=+48H4bzC7vdHlhD2vKB z*t0AGa(3!Ud&IMZ<}<8*Q}*FwBmOhGZ&QSgD)@pR!VMKHuE}F;S_sBkFZLnQ2N{A& zC7eYiQVXRcy`o2kAr1MtDR_x+d)2oERr-S-=n^S9$YC)*AY*_k;)W{o#T>Gr8knn5 z8m0vhKM}k`I3EI>KX;$wvY6*aQRP^i7laAM`2?Rb0Gvq>@YcSTbvH|Lx2kKHVi~KYiY7(;u2MbCL3uG|Lr77x|4vPf( z8tM`1DnB%U;=OYXizg)SC_Q8c#PmH0L^jBr%-QB;gC)C0o@1RfU5HWn-%7HlFk zkPPOm<2B3<=B<8c8qjpH*?+ZASh5$Kwb59#l}LdO4n`UQpo{kFA?R7bAuzTgalEI28 zjyP)Vs2+$tK2Q5nZZ?)_SxZ9uyTeLm^fabgRm>l)T)k=CizWX?Y{9lLLH*jzfu55F z$?^fd3_3G}>ZR&9 z-&|A1FJD*zBAbXUW`biZf(=krUD`O_MEMp{DSX=Nm2PSk75>sWeEb zL>=?UKMU8tk6*Y{o*e6tpWtL9c3orG=bGaX4EwWM{jT4_4j2Pcyto^+#FPD_fmq^% z?uM+mBB6jr-!y3NTqFAHs9|W-nb3%$jm~Ac!yTV$1{0Z>oSbw6x}R?44};jl2gV0u-hNj!ARS|=p%s7M*}>BY?hDHwOKj1J-Nfy zp~q-x@>6hmRxTuKgF8-~;!3^q!$~t~K?*ZgSLpr%JPyP=JnOKGtn?zr<#$#a_p|xx}Btp9T8? zs@y`|RZ`V$X(71lNMq^_{W>sRX9Ha4mS-(p+2J8ECc@?LzM5Kbj{m3)b1>kP^|hWu#|$ zn&GspClyP!e;%ze9FG#MA(hDOT2W6`SZzZTKPTvInhaOBY(iBs?0PI=+Lx?4a`%k| z4F(j?`z@DpND(Nb?RsF(Re0_CnC*KyXH<0{*Z>iHE0AiDiZPadY7)*zG{Y%N?8go5 zwJZl{0nnNmwwi$O`P_ww%|s?|hq;9F^2p-_O$Tu2Wemf!UEO1Nuj0u}0-42zjX8 zfmMGAR4uI24XuO7^SS1b*7uKNn{;NEEl=lMKsfjx>^aVsBOVU|e)?w`$bp!}lKskR;t+w& z+pU%PDpJ$Ip9>kO*oigW4x`wO{p!Xl+`gv>8fN)`n=A$r&wVb?QH;e!9Botp&0gs0 zE*n+jIn24o(2)r4{I$v*w)_6I0!k3=R4d8ZA;3NP`f8olX;bLIThpE!Crkv*R%s

  • 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�okcZtFf{p1hw=P5GV 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