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.