pub struct ClassicalCircuit<const N: usize> {
pub classical_registers: HashMap<String, ClassicalRegister>,
pub operations: Vec<CircuitOp>,
}Expand description
A circuit with classical control flow support
Fields§
§classical_registers: HashMap<String, ClassicalRegister>Classical registers
operations: Vec<CircuitOp>Operations (both quantum and classical)
Implementations§
Source§impl<const N: usize> ClassicalCircuit<N>
impl<const N: usize> ClassicalCircuit<N>
Sourcepub fn add_classical_register(
&mut self,
name: &str,
size: usize,
) -> QuantRS2Result<()>
pub fn add_classical_register( &mut self, name: &str, size: usize, ) -> QuantRS2Result<()>
Add a classical register
Sourcepub fn add_gate<G: GateOp + 'static>(&mut self, gate: G) -> QuantRS2Result<()>
pub fn add_gate<G: GateOp + 'static>(&mut self, gate: G) -> QuantRS2Result<()>
Add a quantum gate
Sourcepub fn measure(
&mut self,
qubit: QubitId,
register: &str,
bit: usize,
) -> QuantRS2Result<()>
pub fn measure( &mut self, qubit: QubitId, register: &str, bit: usize, ) -> QuantRS2Result<()>
Add a measurement
Sourcepub fn add_conditional<G: GateOp + 'static>(
&mut self,
condition: ClassicalCondition,
gate: G,
) -> QuantRS2Result<()>
pub fn add_conditional<G: GateOp + 'static>( &mut self, condition: ClassicalCondition, gate: G, ) -> QuantRS2Result<()>
Add a conditional gate
Adds a gate that will only execute if the classical condition is satisfied.
§Arguments
condition- The classical condition that must be true for the gate to executegate- The quantum gate to execute conditionally
§Errors
Returns an error if:
- The gate acts on invalid qubits (>= N)
- The condition references non-existent classical registers
§Examples
ⓘ
circuit.add_classical_register("measurement", 1)?;
circuit.measure(QubitId(0), "measurement", 0)?;
let condition = ClassicalCondition::register_equals("measurement", 1);
circuit.add_conditional(condition, PauliX { target: QubitId(1) })?;Sourcepub fn reset_classical(&mut self, register: &str) -> QuantRS2Result<()>
pub fn reset_classical(&mut self, register: &str) -> QuantRS2Result<()>
Reset a classical register to zero
Sourcepub fn num_operations(&self) -> usize
pub fn num_operations(&self) -> usize
Get the number of operations
Trait Implementations§
Auto Trait Implementations§
impl<const N: usize> Freeze for ClassicalCircuit<N>
impl<const N: usize> !RefUnwindSafe for ClassicalCircuit<N>
impl<const N: usize> Send for ClassicalCircuit<N>
impl<const N: usize> Sync for ClassicalCircuit<N>
impl<const N: usize> Unpin for ClassicalCircuit<N>
impl<const N: usize> !UnwindSafe for ClassicalCircuit<N>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.