Clifford1Q

Struct Clifford1Q 

Source
pub struct Clifford1Q {
    pub support: [u32; 1],
    pub out_pauli: [u8; 4],
    pub phase: [Phase; 4],
}
Expand description

Single-qubit Clifford gate stored as a 4-entry conjugation table.

out_pauli[i] and phase[i] give the result of G · P_i · G† for the four input Paulis (indexed as above): the new packed Pauli on the support qubit and the i^k phase to fold into the coefficient.

Generic over W so the same gate value can act on any Pauli width.

Fields§

§support: [u32; 1]

Single qubit this gate acts on. Held as [u32; 1] so support() returns a slice without allocation.

§out_pauli: [u8; 4]

Output Pauli bits per input Pauli. Same packing as the index: (out_x | (out_z << 1)). out_pauli[0] is always 0 (I → I).

§phase: [Phase; 4]

Phase factor (i^k) per input Pauli. phase[0] is always Phase::ONE.

Implementations§

Source§

impl Clifford1Q

Source

pub fn h(qubit: u32) -> Self

Hadamard. Conjugation: I → I, X → Z, Z → X, Y → −Y.

Source

pub fn s(qubit: u32) -> Self

Phase gate S = diag(1, i). Conjugation: I → I, X → Y, Z → Z, Y → −X.

Source

pub fn x(qubit: u32) -> Self

Pauli-X gate. Conjugation: I → I, X → X, Z → −Z, Y → −Y.

Source

pub fn y(qubit: u32) -> Self

Pauli-Y gate. Conjugation: I → I, X → −X, Z → −Z, Y → Y.

Source

pub fn z(qubit: u32) -> Self

Pauli-Z gate. Conjugation: I → I, X → −X, Z → Z, Y → −Y.

Source

pub fn adjoint(&self) -> Self

Conjugation table for G†. Inverts the Pauli permutation and conjugates the per-input phases: if G P_a G† = c_a · P_{f(a)} then G† P_{f(a)} G = c_a* · P_a.

Self-inverse 1Q Cliffords (H, X, Y, Z) round-trip to themselves; S returns S† (a distinct gate).

Trait Implementations§

Source§

impl<const W: usize> Channel<W> for Clifford1Q

Source§

fn max_fanout(&self) -> usize

Maximum number of output terms produced per input term. Used by the engine to size the scratch buffer up-front.
Source§

fn support(&self) -> &[u32]

Qubits this channel acts on. Outputs differ from inputs only at these bit positions; the engine uses this for bucket layout (§5).
Source§

fn apply( &self, input_x: &[u64; W], input_z: &[u64; W], coeff: Complex64, out: &mut OutputBuffer<'_, W>, )

Apply the channel to a single input term, writing outputs to out.
Source§

fn apply_adjoint( &self, input_x: &[u64; W], input_z: &[u64; W], coeff: Complex64, out: &mut OutputBuffer<'_, W>, )

Apply the channel’s adjoint to a single input term, writing outputs to out. Used by the engine in Direction::Heisenberg mode for backpropagating observables. Read more
Source§

impl Clone for Clifford1Q

Source§

fn clone(&self) -> Clifford1Q

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Clifford1Q

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Copy for Clifford1Q

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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 more
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.