Skip to main content

U1Algebra

Struct U1Algebra 

Source
pub struct U1Algebra(pub f64);
Expand description

Lie algebra u(1) ≅ ℝ

The Lie algebra of U(1) consists of purely imaginary numbers i·a where a ∈ ℝ. We represent this as a 1-dimensional real vector space.

§Mathematical Structure

Elements of u(1) have the form:

X = i·a where a ∈ ℝ

The exponential map is simply:

exp(i·a) = e^{ia} ∈ U(1)

§Examples

use lie_groups::u1::U1Algebra;
use lie_groups::traits::LieAlgebra;

// Create algebra element
let v = U1Algebra::from_components(&[1.5]);

// Scale
let w = v.scale(2.0);
assert_eq!(w.value(), 3.0);

Tuple Fields§

§0: f64

Implementations§

Source§

impl U1Algebra

Source

pub fn value(&self) -> f64

Get the real value a from the algebra element i·a

Trait Implementations§

Source§

impl Add<&U1Algebra> for &U1Algebra

Source§

type Output = U1Algebra

The resulting type after applying the + operator.
Source§

fn add(self, rhs: &U1Algebra) -> U1Algebra

Performs the + operation. Read more
Source§

impl Add<&U1Algebra> for U1Algebra

Source§

type Output = U1Algebra

The resulting type after applying the + operator.
Source§

fn add(self, rhs: &U1Algebra) -> U1Algebra

Performs the + operation. Read more
Source§

impl Add<U1Algebra> for &U1Algebra

Source§

type Output = U1Algebra

The resulting type after applying the + operator.
Source§

fn add(self, rhs: U1Algebra) -> U1Algebra

Performs the + operation. Read more
Source§

impl Add for U1Algebra

Source§

type Output = U1Algebra

The resulting type after applying the + operator.
Source§

fn add(self, rhs: Self) -> Self

Performs the + operation. Read more
Source§

impl Clone for U1Algebra

Source§

fn clone(&self) -> U1Algebra

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 U1Algebra

Source§

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

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

impl Display for U1Algebra

Source§

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

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

impl LieAlgebra for U1Algebra

Source§

const DIM: usize = 1

Dimension of the Lie algebra as a compile-time constant. Read more
Source§

fn zero() -> Self

Zero element (additive identity) 0 ∈ 𝔤. Read more
Source§

fn add(&self, other: &Self) -> Self

Add two algebra elements: v + w Read more
Source§

fn scale(&self, scalar: f64) -> Self

Scalar multiplication: α · v Read more
Source§

fn norm(&self) -> f64

Euclidean norm: ||v|| Read more
Source§

fn basis_element(i: usize) -> Self

Get the i-th basis element of the Lie algebra. Read more
Source§

fn from_components(components: &[f64]) -> Self

Construct algebra element from basis coordinates. Read more
Source§

fn to_components(&self) -> Vec<f64>

Extract basis coordinates from algebra element. Read more
Source§

fn bracket(&self, _other: &Self) -> Self

Lie bracket operation: [X, Y] ∈ 𝔤 Read more
Source§

fn dim() -> usize

Dimension of the Lie algebra (dim 𝔤). Read more
Source§

fn inner(&self, other: &Self) -> f64

Inner product: ⟨v, w⟩ Read more
Source§

impl Mul<U1Algebra> for f64

Source§

type Output = U1Algebra

The resulting type after applying the * operator.
Source§

fn mul(self, rhs: U1Algebra) -> U1Algebra

Performs the * operation. Read more
Source§

impl Mul<f64> for U1Algebra

Source§

type Output = U1Algebra

The resulting type after applying the * operator.
Source§

fn mul(self, scalar: f64) -> Self

Performs the * operation. Read more
Source§

impl Neg for U1Algebra

Source§

type Output = U1Algebra

The resulting type after applying the - operator.
Source§

fn neg(self) -> Self

Performs the unary - operation. Read more
Source§

impl PartialEq for U1Algebra

Source§

fn eq(&self, other: &U1Algebra) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Sub for U1Algebra

Source§

type Output = U1Algebra

The resulting type after applying the - operator.
Source§

fn sub(self, rhs: Self) -> Self

Performs the - operation. Read more
Source§

impl AntiHermitianByConstruction for U1Algebra

u(1) algebra elements are anti-Hermitian by construction.

The representation U1Algebra(f64) stores a real number a representing the purely imaginary element ia ∈ iℝ ⊂ ℂ. Since (ia)* = -ia, these are anti-Hermitian (as 1×1 complex matrices).

§Note: NOT TracelessByConstruction

Unlike su(n), the u(1) algebra is NOT traceless. For a 1×1 matrix [ia], the trace is ia ≠ 0 (for a ≠ 0). This is why U(1) ≠ SU(1).

The theorem det(exp(X)) = exp(tr(X)) still holds, but gives:

  • det(exp(ia)) = exp(ia) ≠ 1 in general
  • This is correct: U(1) elements have |det| = 1, not det = 1
Source§

impl Copy for U1Algebra

Source§

impl StructuralPartialEq for U1Algebra

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> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<SS, SP> SupersetOf<SS> for SP
where SS: SubsetOf<SP>,

Source§

fn to_subset(&self) -> Option<SS>

The inverse inclusion map: attempts to construct self from the equivalent element of its superset. Read more
Source§

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

Use with care! Same as self.to_subset but without any property checks. Always succeeds.
Source§

fn from_subset(element: &SS) -> SP

The inclusion map: converts self to the equivalent element of its superset.
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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> ClosedNeg for T
where T: Neg<Output = T>,

Source§

impl<T> Scalar for T
where T: 'static + Clone + PartialEq + Debug,