pub struct MultiControlledGate { /* private fields */ }Expand description
Multi-controlled gate with optimizations for common patterns
Implementations§
Source§impl MultiControlledGate
impl MultiControlledGate
Sourcepub fn new(
positive_controls: Vec<QubitId>,
negative_controls: Vec<QubitId>,
base_gate: Box<dyn GateOp>,
) -> Self
pub fn new( positive_controls: Vec<QubitId>, negative_controls: Vec<QubitId>, base_gate: Box<dyn GateOp>, ) -> Self
Create a new multi-controlled gate
Sourcepub fn positive(controls: Vec<QubitId>, base_gate: Box<dyn GateOp>) -> Self
pub fn positive(controls: Vec<QubitId>, base_gate: Box<dyn GateOp>) -> Self
Create with only positive controls
Sourcepub fn num_controls(&self) -> usize
pub fn num_controls(&self) -> usize
Get total number of control qubits
Trait Implementations§
Source§impl Debug for MultiControlledGate
impl Debug for MultiControlledGate
Source§impl GateOp for MultiControlledGate
impl GateOp for MultiControlledGate
Source§fn is_parameterized(&self) -> bool
fn is_parameterized(&self) -> bool
Returns true if this gate is parameterized
Source§fn matrix(&self) -> QuantRS2Result<Vec<Complex64>>
fn matrix(&self) -> QuantRS2Result<Vec<Complex64>>
Returns the matrix representation of this gate
Source§fn clone_gate(&self) -> Box<dyn GateOp>
fn clone_gate(&self) -> Box<dyn GateOp>
Clone the gate into a new boxed instance
Source§fn num_qubits(&self) -> usize
fn num_qubits(&self) -> usize
Returns the number of qubits this gate acts on
Auto Trait Implementations§
impl Freeze for MultiControlledGate
impl !RefUnwindSafe for MultiControlledGate
impl Send for MultiControlledGate
impl Sync for MultiControlledGate
impl Unpin for MultiControlledGate
impl !UnwindSafe for MultiControlledGate
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.