Struct num::Complex
[−]
[src]
#[repr(C)]pub struct Complex<T> { pub re: T, pub im: T, }
A complex number in Cartesian form.
Representation and Foreign Function Interface Compatibility
Complex<T>
is memory layout compatible with an array [T; 2]
.
Note that Complex<F>
where F is a floating point type is only memory
layout compatible with C's complex types, not necessarily calling
convention compatible. This means that for FFI you can only pass
Complex<F>
behind a pointer, not as a value.
Examples
Example of extern function declaration.
use num_complex::Complex; use std::os::raw::c_int; extern "C" { fn zaxpy_(n: *const c_int, alpha: *const Complex<f64>, x: *const Complex<f64>, incx: *const c_int, y: *mut Complex<f64>, incy: *const c_int); }Run
Fields
re: T
Real portion of the complex number
im: T
Imaginary portion of the complex number
Methods
impl<T> Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
fn new(re: T, im: T) -> Complex<T>
Create a new Complex
fn i() -> Complex<T>
Returns imaginary unit
fn norm_sqr(&self) -> T
Returns the square of the norm (since T
doesn't necessarily
have a sqrt function), i.e. re^2 + im^2
.
fn scale(&self, t: T) -> Complex<T>
Multiplies self
by the scalar t
.
fn unscale(&self, t: T) -> Complex<T>
Divides self
by the scalar t
.
impl<T> Complex<T> where
T: Neg<Output = T> + Clone + Num,
[src]
T: Neg<Output = T> + Clone + Num,
fn conj(&self) -> Complex<T>
Returns the complex conjugate. i.e. re - i im
fn inv(&self) -> Complex<T>
Returns 1/self
impl<T> Complex<T> where
T: Clone + Float,
[src]
T: Clone + Float,
fn norm(&self) -> T
Calculate |self|
fn arg(&self) -> T
Calculate the principal Arg of self.
fn to_polar(&self) -> (T, T)
Convert to polar form (r, theta), such that `self = r * exp(i
- theta)`
fn from_polar(r: &T, theta: &T) -> Complex<T>
Convert a polar representation into a complex number.
fn exp(&self) -> Complex<T>
Computes e^(self)
, where e
is the base of the natural logarithm.
fn ln(&self) -> Complex<T>
Computes the principal value of natural logarithm of self
.
This function has one branch cut:
(-∞, 0]
, continuous from above.
The branch satisfies -π ≤ arg(ln(z)) ≤ π
.
fn sqrt(&self) -> Complex<T>
Computes the principal value of the square root of self
.
This function has one branch cut:
(-∞, 0)
, continuous from above.
The branch satisfies -π/2 ≤ arg(sqrt(z)) ≤ π/2
.
fn powf(&self, exp: T) -> Complex<T>
Raises self
to a floating point power.
fn log(&self, base: T) -> Complex<T>
Returns the logarithm of self
with respect to an arbitrary base.
fn powc(&self, exp: Complex<T>) -> Complex<T>
Raises self
to a complex power.
fn expf(&self, base: T) -> Complex<T>
Raises a floating point number to the complex power self
.
fn sin(&self) -> Complex<T>
Computes the sine of self
.
fn cos(&self) -> Complex<T>
Computes the cosine of self
.
fn tan(&self) -> Complex<T>
Computes the tangent of self
.
fn asin(&self) -> Complex<T>
Computes the principal value of the inverse sine of self
.
This function has two branch cuts:
(-∞, -1)
, continuous from above.(1, ∞)
, continuous from below.
The branch satisfies -π/2 ≤ Re(asin(z)) ≤ π/2
.
fn acos(&self) -> Complex<T>
Computes the principal value of the inverse cosine of self
.
This function has two branch cuts:
(-∞, -1)
, continuous from above.(1, ∞)
, continuous from below.
The branch satisfies 0 ≤ Re(acos(z)) ≤ π
.
fn atan(&self) -> Complex<T>
Computes the principal value of the inverse tangent of self
.
This function has two branch cuts:
(-∞i, -i]
, continuous from the left.[i, ∞i)
, continuous from the right.
The branch satisfies -π/2 ≤ Re(atan(z)) ≤ π/2
.
fn sinh(&self) -> Complex<T>
Computes the hyperbolic sine of self
.
fn cosh(&self) -> Complex<T>
Computes the hyperbolic cosine of self
.
fn tanh(&self) -> Complex<T>
Computes the hyperbolic tangent of self
.
fn asinh(&self) -> Complex<T>
Computes the principal value of inverse hyperbolic sine of self
.
This function has two branch cuts:
(-∞i, -i)
, continuous from the left.(i, ∞i)
, continuous from the right.
The branch satisfies -π/2 ≤ Im(asinh(z)) ≤ π/2
.
fn acosh(&self) -> Complex<T>
Computes the principal value of inverse hyperbolic cosine of self
.
This function has one branch cut:
(-∞, 1)
, continuous from above.
The branch satisfies -π ≤ Im(acosh(z)) ≤ π
and 0 ≤ Re(acosh(z)) < ∞
.
fn atanh(&self) -> Complex<T>
Computes the principal value of inverse hyperbolic tangent of self
.
This function has two branch cuts:
(-∞, -1]
, continuous from above.[1, ∞)
, continuous from below.
The branch satisfies -π/2 ≤ Im(atanh(z)) ≤ π/2
.
fn is_nan(self) -> bool
Checks if the given complex number is NaN
fn is_infinite(self) -> bool
Checks if the given complex number is infinite
fn is_finite(self) -> bool
Checks if the given complex number is finite
fn is_normal(self) -> bool
Checks if the given complex number is normal
Trait Implementations
impl<T> Decodable for Complex<T> where
T: Decodable,
[src]
T: Decodable,
impl<T> Eq for Complex<T> where
T: Eq,
[src]
T: Eq,
impl<T> Octal for Complex<T> where
T: Octal + Num + PartialOrd<T> + Clone,
[src]
T: Octal + Num + PartialOrd<T> + Clone,
impl<T> FromStr for Complex<T> where
T: FromStr + Num + Clone,
[src]
T: FromStr + Num + Clone,
type Err = ParseComplexError<T::Err>
fn from_str(s: &str) -> Result<Complex<T>, Complex<T>::Err>
Parses a +/- bi
; ai +/- b
; a
; or bi
where a
and b
are of type T
impl<T> Default for Complex<T> where
T: Default,
[src]
T: Default,
impl<T> MulAssign<Complex<T>> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn mul_assign(&mut self, other: Complex<T>)
impl<T> MulAssign<T> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn mul_assign(&mut self, other: T)
impl<'a, T> MulAssign<&'a Complex<T>> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn mul_assign(&mut self, other: &Complex<T>)
impl<'a, T> MulAssign<&'a T> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn mul_assign(&mut self, other: &T)
impl<T> Copy for Complex<T> where
T: Copy,
[src]
T: Copy,
impl<T> AddAssign<Complex<T>> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn add_assign(&mut self, other: Complex<T>)
impl<T> AddAssign<T> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn add_assign(&mut self, other: T)
impl<'a, T> AddAssign<&'a Complex<T>> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn add_assign(&mut self, other: &Complex<T>)
impl<'a, T> AddAssign<&'a T> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn add_assign(&mut self, other: &T)
impl<T> Mul<Complex<T>> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<T> Mul<T> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, 'b, T> Mul<&'b Complex<T>> for &'a Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Mul<Complex<T>> for &'a Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Mul<&'a Complex<T>> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Mul<&'a T> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Mul<T> for &'a Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, 'b, T> Mul<&'a T> for &'b Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<T> Display for Complex<T> where
T: Display + Num + PartialOrd<T> + Clone,
[src]
T: Display + Num + PartialOrd<T> + Clone,
impl<T> DivAssign<Complex<T>> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn div_assign(&mut self, other: Complex<T>)
impl<T> DivAssign<T> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn div_assign(&mut self, other: T)
impl<'a, T> DivAssign<&'a Complex<T>> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn div_assign(&mut self, other: &Complex<T>)
impl<'a, T> DivAssign<&'a T> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn div_assign(&mut self, other: &T)
impl<T> Sub<Complex<T>> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<T> Sub<T> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, 'b, T> Sub<&'b Complex<T>> for &'a Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Sub<Complex<T>> for &'a Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Sub<&'a Complex<T>> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Sub<&'a T> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Sub<T> for &'a Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, 'b, T> Sub<&'a T> for &'b Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<T> LowerExp for Complex<T> where
T: LowerExp + Num + PartialOrd<T> + Clone,
[src]
T: LowerExp + Num + PartialOrd<T> + Clone,
impl<T> UpperExp for Complex<T> where
T: UpperExp + Num + PartialOrd<T> + Clone,
[src]
T: UpperExp + Num + PartialOrd<T> + Clone,
impl<T> UpperHex for Complex<T> where
T: UpperHex + Num + PartialOrd<T> + Clone,
[src]
T: UpperHex + Num + PartialOrd<T> + Clone,
impl<T> One for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<T> Debug for Complex<T> where
T: Debug,
[src]
T: Debug,
impl<T> Add<Complex<T>> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<T> Add<T> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, 'b, T> Add<&'b Complex<T>> for &'a Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Add<Complex<T>> for &'a Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Add<&'a Complex<T>> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Add<&'a T> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Add<T> for &'a Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, 'b, T> Add<&'a T> for &'b Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<T> PartialEq<Complex<T>> for Complex<T> where
T: PartialEq<T>,
[src]
T: PartialEq<T>,
impl<T> Clone for Complex<T> where
T: Clone,
[src]
T: Clone,
impl<T> Binary for Complex<T> where
T: Binary + Num + PartialOrd<T> + Clone,
[src]
T: Binary + Num + PartialOrd<T> + Clone,
impl<T> Zero for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
fn zero() -> Complex<T>
Returns the additive identity element of Self
, 0
. Read more
fn is_zero(&self) -> bool
Returns true
if self
is equal to the additive identity.
impl<T> Neg for Complex<T> where
T: Neg<Output = T> + Clone + Num,
[src]
T: Neg<Output = T> + Clone + Num,
impl<'a, T> Neg for &'a Complex<T> where
T: Neg<Output = T> + Clone + Num,
[src]
T: Neg<Output = T> + Clone + Num,
impl<T> LowerHex for Complex<T> where
T: LowerHex + Num + PartialOrd<T> + Clone,
[src]
T: LowerHex + Num + PartialOrd<T> + Clone,
impl<T> SubAssign<Complex<T>> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn sub_assign(&mut self, other: Complex<T>)
impl<T> SubAssign<T> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn sub_assign(&mut self, other: T)
impl<'a, T> SubAssign<&'a Complex<T>> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn sub_assign(&mut self, other: &Complex<T>)
impl<'a, T> SubAssign<&'a T> for Complex<T> where
T: Clone + NumAssign,
[src]
T: Clone + NumAssign,
fn sub_assign(&mut self, other: &T)
impl<T> From<T> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> From<&'a T> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<T> Hash for Complex<T> where
T: Hash,
[src]
T: Hash,
impl<T> Div<Complex<T>> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<T> Div<T> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, 'b, T> Div<&'b Complex<T>> for &'a Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Div<Complex<T>> for &'a Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Div<&'a Complex<T>> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Div<&'a T> for Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, T> Div<T> for &'a Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<'a, 'b, T> Div<&'a T> for &'b Complex<T> where
T: Clone + Num,
[src]
T: Clone + Num,
impl<T> Encodable for Complex<T> where
T: Encodable,
[src]
T: Encodable,