Skip to main content

Complex

Struct Complex 

Source
pub struct Complex<T: RealField> {
    pub re: T,
    pub im: T,
}
Expand description

Represents a complex number with real and imaginary parts.

A complex number is a number that can be expressed in the form a + bi, where a and b are real numbers, and i is the imaginary unit, satisfying the equation i^2 = -1.

The Complex struct is generic over a type T that implements RealField, allowing it to work with different floating-point precisions (e.g., f32 or f64).

§Fields

  • re: The real part of the complex number.
  • im: The imaginary part of the complex number.

§Examples

use deep_causality_num::Complex;

let c1 = Complex::new(1.0, 2.0); // Represents 1.0 + 2.0i
let c2 = Complex { re: 3.0, im: -1.0 }; // Represents 3.0 - 1.0i

assert_eq!(c1.re, 1.0);
assert_eq!(c2.im, -1.0);

Fields§

§re: T§im: T

Implementations§

Source§

impl<T: RealField> Complex<T>

Source

pub fn norm(&self) -> T

Computes the norm (magnitude or absolute value) of the complex number.

Source

pub fn arg(&self) -> T

Computes the argument (phase angle) of the complex number in radians.

Source

pub fn powi(&self, n: i32) -> Self

Raises to an integer power.

Source

pub fn powf(&self, n: T) -> Self

Raises a to a real (scalar) power.

Source

pub fn powc(&self, n: Self) -> Self

Raises to a complex power.

Source

pub fn sqrt(self) -> Self

Computes the principal square root of a complex number.

Source

pub fn exp(self) -> Self

Computes e^(self), where e is the base of the natural logarithm.

Source

pub fn ln(self) -> Self

Computes the natural logarithm of a complex number.

Source

pub fn sin(self) -> Self

Computes the sine of a complex number.

Source

pub fn cos(self) -> Self

Computes the cosine of a complex number.

Source

pub fn tan(self) -> Self

Computes the tangent of a complex number.

Source

pub fn sinh(self) -> Self

Computes the hyperbolic sine of a complex number.

Source

pub fn cosh(self) -> Self

Computes the hyperbolic cosine of a complex number.

Source

pub fn tanh(self) -> Self

Computes the hyperbolic tangent of a complex number.

Source§

impl<T: RealField> Complex<T>

Source

pub fn new(re: T, im: T) -> Self

Creates a new complex number from its real and imaginary parts.

Source

pub fn from_real(re: T) -> Self

Creates a new complex number from a real number.

Source§

impl<T: RealField> Complex<T>

Source

pub fn re(&self) -> T

Returns the real part of the complex number.

Source

pub fn im(&self) -> T

Returns the imaginary part of the complex number.

Trait Implementations§

Source§

impl<T: RealField> Add<T> for Complex<T>

Source§

type Output = Complex<T>

The resulting type after applying the + operator.
Source§

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

Performs the + operation. Read more
Source§

impl<T: RealField> Add for Complex<T>

Source§

type Output = Complex<T>

The resulting type after applying the + operator.
Source§

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

Performs the + operation. Read more
Source§

impl<T: RealField> AddAssign<T> for Complex<T>

Source§

fn add_assign(&mut self, rhs: T)

Performs the += operation. Read more
Source§

impl<T: RealField> AddAssign for Complex<T>

Source§

fn add_assign(&mut self, rhs: Self)

Performs the += operation. Read more
Source§

impl<T, U> AsPrimitive<U> for Complex<T>
where T: RealField + AsPrimitive<U> + 'static, U: 'static + Copy,

Source§

fn as_(self) -> U

Convert a value to another, using the as operator.
Source§

impl<T: Clone + RealField> Clone for Complex<T>

Source§

fn clone(&self) -> Complex<T>

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<T: RealField> ComplexField<T> for Complex<T>

Source§

fn real(&self) -> T

Returns the real part of the complex number. Read more
Source§

fn imag(&self) -> T

Returns the imaginary part of the complex number. Read more
Source§

fn conjugate(&self) -> Self

Returns the complex conjugate. Read more
Source§

fn norm_sqr(&self) -> T

Returns the squared modulus (norm squared). Read more
Source§

fn norm(&self) -> T

Returns the modulus (absolute value). Read more
Source§

fn arg(&self) -> T

Returns the argument (phase angle) in radians. Read more
Source§

fn from_re_im(re: T, im: T) -> Self

Constructs a complex number from real and imaginary parts. Read more
Source§

fn from_polar(r: T, theta: T) -> Self

Constructs a complex number from polar form. Read more
Source§

fn i() -> Self

Returns the imaginary unit i. Read more
Source§

fn is_real(&self) -> bool

Returns true if the imaginary part is zero.
Source§

fn is_imaginary(&self) -> bool

Returns true if the real part is zero.
Source§

impl<T> ConstOne for Complex<T>

Source§

const ONE: Self

The multiplicative identity element of Self, 1.
Source§

impl<T> ConstZero for Complex<T>
where T: RealField + ConstZero,

Source§

const ZERO: Self

The additive identity element of Self, 0.
Source§

impl<T: Debug + RealField> Debug for Complex<T>

Source§

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

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

impl<T: Default + RealField> Default for Complex<T>

Source§

fn default() -> Complex<T>

Returns the “default value” for a type. Read more
Source§

impl<T: RealField + Display> Display for Complex<T>

Source§

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

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

impl<T: RealField> Div<T> for Complex<T>

Source§

type Output = Complex<T>

The resulting type after applying the / operator.
Source§

fn div(self, rhs: T) -> Self

Performs the / operation. Read more
Source§

impl<T: RealField> Div for Complex<T>

Source§

type Output = Complex<T>

The resulting type after applying the / operator.
Source§

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

Performs the / operation. Read more
Source§

impl<T: RealField> DivAssign<T> for Complex<T>

Source§

fn div_assign(&mut self, rhs: T)

Performs the /= operation. Read more
Source§

impl<T: RealField> DivAssign for Complex<T>

Source§

fn div_assign(&mut self, rhs: Self)

Performs the /= operation. Read more
Source§

impl<T: RealField> DivisionAlgebra<T> for Complex<T>

Source§

fn conjugate(&self) -> Self

Computes the conjugate of an element. Read more
Source§

fn norm_sqr(&self) -> T

Computes the squared norm of an element. Read more
Source§

fn inverse(&self) -> Self

Computes the multiplicative inverse of an element. Read more
Source§

impl<T: RealField + FromPrimitive> FromPrimitive for Complex<T>

Source§

fn from_isize(n: isize) -> Option<Self>

Converts an isize to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
Source§

fn from_i8(n: i8) -> Option<Self>

Converts an i8 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
Source§

fn from_i16(n: i16) -> Option<Self>

Converts an i16 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
Source§

fn from_i32(n: i32) -> Option<Self>

Converts an i32 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
Source§

fn from_i64(n: i64) -> Option<Self>

Converts an i64 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
Source§

fn from_i128(n: i128) -> Option<Self>

Converts an i128 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
Source§

fn from_usize(n: usize) -> Option<Self>

Converts a usize to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
Source§

fn from_u8(n: u8) -> Option<Self>

Converts an u8 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
Source§

fn from_u16(n: u16) -> Option<Self>

Converts an u16 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
Source§

fn from_u32(n: u32) -> Option<Self>

Converts an u32 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
Source§

fn from_u64(n: u64) -> Option<Self>

Converts an u64 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
Source§

fn from_u128(n: u128) -> Option<Self>

Converts an u128 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
Source§

fn from_f32(n: f32) -> Option<Self>

Converts a f32 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
Source§

fn from_f64(n: f64) -> Option<Self>

Converts a f64 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
Source§

impl<T: RealField> Mul<T> for Complex<T>

Source§

type Output = Complex<T>

The resulting type after applying the * operator.
Source§

fn mul(self, rhs: T) -> Self

Performs the * operation. Read more
Source§

impl<T: RealField> Mul for Complex<T>

Source§

type Output = Complex<T>

The resulting type after applying the * operator.
Source§

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

Performs the * operation. Read more
Source§

impl<T: RealField> MulAssign<T> for Complex<T>

Source§

fn mul_assign(&mut self, rhs: T)

Performs the *= operation. Read more
Source§

impl<T: RealField> MulAssign for Complex<T>

Source§

fn mul_assign(&mut self, rhs: Self)

Performs the *= operation. Read more
Source§

impl<T: RealField> Neg for Complex<T>

Source§

type Output = Complex<T>

The resulting type after applying the - operator.
Source§

fn neg(self) -> Self

Performs the unary - operation. Read more
Source§

impl<T: RealField + NumCast> NumCast for Complex<T>

Source§

fn from<N: ToPrimitive>(n: N) -> Option<Self>

Creates a number from another value that can be converted into a primitive via the ToPrimitive trait. If the source value cannot be represented by the target type, then None is returned. Read more
Source§

impl<T> One for Complex<T>
where T: RealField,

Source§

fn one() -> Self

Returns the multiplicative identity element of Self, 1. Read more
Source§

fn is_one(&self) -> bool

Returns true if self is equal to the multiplicative identity.
Source§

fn set_one(&mut self)

Sets self to the multiplicative identity element of Self, 1.
Source§

impl<T: RealField + Ord> Ord for Complex<T>

Source§

fn cmp(&self, other: &Self) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl<T: PartialEq + RealField> PartialEq for Complex<T>

Source§

fn eq(&self, other: &Complex<T>) -> 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<T: RealField> PartialOrd for Complex<T>

Source§

fn partial_cmp(&self, other: &Self) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

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

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

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

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

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

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

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

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl<T: RealField> Product for Complex<T>

Source§

fn product<I: Iterator<Item = Self>>(iter: I) -> Self

Takes an iterator and generates Self from the elements by multiplying the items.
Source§

impl<T: RealField> Rotation<T> for Complex<T>

Source§

fn rotate_x(&self, _angle: T) -> Self

Rotation around the X-axis. Quaternions: Axis i. Quantum: Pauli X.
Source§

fn rotate_y(&self, _angle: T) -> Self

Rotation around the Y-axis. Quaternions: Axis j. Quantum: Pauli Y.
Source§

fn rotate_z(&self, angle: T) -> Self

Rotation around the Z-axis (Phase). Quaternions: Axis k. Quantum: Pauli Z.
Source§

fn global_phase(&self, angle: T) -> Self

Global Phase Shift. $P(\phi) = e^{i\phi}$.
Source§

impl<T: RealField> Sub<T> for Complex<T>

Source§

type Output = Complex<T>

The resulting type after applying the - operator.
Source§

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

Performs the - operation. Read more
Source§

impl<T: RealField> Sub for Complex<T>

Source§

type Output = Complex<T>

The resulting type after applying the - operator.
Source§

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

Performs the - operation. Read more
Source§

impl<T: RealField> SubAssign<T> for Complex<T>

Source§

fn sub_assign(&mut self, rhs: T)

Performs the -= operation. Read more
Source§

impl<T: RealField> SubAssign for Complex<T>

Source§

fn sub_assign(&mut self, rhs: Self)

Performs the -= operation. Read more
Source§

impl<T: RealField> Sum for Complex<T>

Source§

fn sum<I: Iterator<Item = Self>>(iter: I) -> Self

Takes an iterator and generates Self from the elements by “summing up” the items.
Source§

impl<T: RealField + ToPrimitive> ToPrimitive for Complex<T>

Source§

fn to_isize(&self) -> Option<isize>

Converts the value of self to an isize. If the value cannot be represented by an isize, then None is returned.
Source§

fn to_i8(&self) -> Option<i8>

Converts the value of self to an i8. If the value cannot be represented by an i8, then None is returned.
Source§

fn to_i16(&self) -> Option<i16>

Converts the value of self to an i16. If the value cannot be represented by an i16, then None is returned.
Source§

fn to_i32(&self) -> Option<i32>

Converts the value of self to an i32. If the value cannot be represented by an i32, then None is returned.
Source§

fn to_i64(&self) -> Option<i64>

Converts the value of self to an i64. If the value cannot be represented by an i64, then None is returned.
Source§

fn to_i128(&self) -> Option<i128>

Converts the value of self to an i128. If the value cannot be represented by an i128 (i64 under the default implementation), then None is returned. Read more
Source§

fn to_usize(&self) -> Option<usize>

Converts the value of self to a usize. If the value cannot be represented by a usize, then None is returned.
Source§

fn to_u8(&self) -> Option<u8>

Converts the value of self to a u8. If the value cannot be represented by a u8, then None is returned.
Source§

fn to_u16(&self) -> Option<u16>

Converts the value of self to a u16. If the value cannot be represented by a u16, then None is returned.
Source§

fn to_u32(&self) -> Option<u32>

Converts the value of self to a u32. If the value cannot be represented by a u32, then None is returned.
Source§

fn to_u64(&self) -> Option<u64>

Converts the value of self to a u64. If the value cannot be represented by a u64, then None is returned.
Source§

fn to_u128(&self) -> Option<u128>

Converts the value of self to a u128. If the value cannot be represented by a u128 (u64 under the default implementation), then None is returned.
Source§

fn to_f32(&self) -> Option<f32>

Converts the value of self to an f32. Overflows may map to positive or negative inifinity, otherwise None is returned if the value cannot be represented by an f32.
Source§

fn to_f64(&self) -> Option<f64>

Converts the value of self to an f64. Overflows may map to positive or negative inifinity, otherwise None is returned if the value cannot be represented by an f64.
Source§

impl<T> Zero for Complex<T>
where T: RealField,

Source§

fn zero() -> Self

Returns the additive identity element of Self, 0. Read more
Source§

fn is_zero(&self) -> bool

Returns true if self is equal to the additive identity.
Source§

fn set_zero(&mut self)

Sets self to the additive identity element of Self, 0.
Source§

impl<T: RealField> AbelianGroup for Complex<T>

Source§

impl<T: RealField> Associative for Complex<T>

Source§

impl<T: RealField> Commutative for Complex<T>

Source§

impl<T: Copy + RealField> Copy for Complex<T>

Source§

impl<T: RealField> Distributive for Complex<T>

Source§

impl<T: RealField> Eq for Complex<T>

Source§

impl<T: RealField> StructuralPartialEq for Complex<T>

Auto Trait Implementations§

§

impl<T> Freeze for Complex<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for Complex<T>
where T: RefUnwindSafe,

§

impl<T> Send for Complex<T>
where T: Send,

§

impl<T> Sync for Complex<T>
where T: Sync,

§

impl<T> Unpin for Complex<T>
where T: Unpin,

§

impl<T> UnwindSafe for Complex<T>
where T: UnwindSafe,

Blanket Implementations§

Source§

impl<T, R> Algebra<R> for T
where T: Module<R, Output = T> + Mul + MulAssign + One + Distributive, R: Ring,

Source§

fn sqr(&self) -> Self

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> InvMonoid for T
where T: MulMonoid + Div<Output = T> + DivAssign + One + Clone,

Source§

fn inverse(&self) -> T

Computes the multiplicative inverse of an element. Read more
Source§

impl<V, R> Module<R> for V
where V: AbelianGroup + Mul<R, Output = V> + MulAssign<R>, R: Ring,

Source§

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

Scales the module element by a scalar from the ring R. Read more
Source§

fn scale_mut(&mut self, scalar: R)

Scales the module element in-place by a scalar from the ring R. 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> 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<T> AddGroup for T
where T: Sub<Output = T> + Add<Output = T> + Zero + Clone,

Source§

impl<T> AddMagma for T
where T: Add<Output = T> + AddAssign + Clone + PartialEq,

Source§

impl<T> AddMonoid for T
where T: Add<Output = T> + AddAssign + Zero + Clone,

Source§

impl<T> AddSemigroup for T
where T: Add<Output = T> + Associative + Clone,

Source§

impl<T, R> AssociativeAlgebra<R> for T
where T: Algebra<R> + Ring, R: Ring,

Source§

impl<T, R> AssociativeDivisionAlgebra<R> for T

Source§

impl<T> AssociativeRing for T
where T: Ring + Associative,

Source§

impl<T> CommutativeRing for T
where T: Ring + Commutative,

Source§

impl<T> DivGroup for T
where T: MulGroup,

Source§

impl<T> Field for T
where T: CommutativeRing + InvMonoid<Output = T> + Div + DivAssign,

Source§

impl<T> Group for T
where T: AddGroup,

Source§

impl<T> MulGroup for T
where T: MulMonoid + InvMonoid<Output = T> + Div + DivAssign,

Source§

impl<T> MulMagma for T
where T: Mul<Output = T> + Clone,

Source§

impl<T> MulMonoid for T
where T: MulMagma + One + Associative,

Source§

impl<T> MulSemigroup for T
where T: Mul<Output = T> + Associative + Clone,

Source§

impl<T> Ring for T