Skip to main content

SpecialError

Enum SpecialError 

Source
pub enum SpecialError {
    ComputationError(String),
    DomainError(String),
    ValueError(String),
    NotImplementedError(String),
    ConvergenceError(String),
    OverflowError(String),
    GpuNotAvailable(String),
    CoreError(CoreError),
}
Expand description

Error types for special function computations

This enum provides detailed error information for different failure modes that can occur during special function computations. Each variant includes contextual information to help users understand and resolve issues.

Variants§

§

ComputationError(String)

Generic computation error for unexpected failures

Used when a computation fails for reasons not covered by more specific error types. Often indicates internal algorithmic issues or unexpected edge cases.

§Examples

  • Numerical integration failure
  • Memory allocation failure during computation
  • Internal algorithm assertion failure
§

DomainError(String)

Mathematical domain error - input outside the valid mathematical domain

Thrown when function arguments are outside the mathematical domain where the function is defined. This follows mathematical conventions strictly.

§Examples

  • gamma(-1) - gamma function undefined at negative integers
  • sqrt(-1) for real-valued square root
  • log(0) or log(negative) for real logarithm
  • asin(2) - arcsine undefined outside [-1, 1]
§

ValueError(String)

Input validation error for invalid parameter values

Used for parameter validation failures where inputs don’t meet function requirements (but may be mathematically valid elsewhere).

§Examples

  • Negative array dimensions
  • Invalid tolerance parameters (e.g., negative tolerance)
  • Array shape mismatches
  • Invalid enumeration values
§

NotImplementedError(String)

Feature or function not yet implemented

Indicates that a requested feature exists in the API but hasn’t been implemented yet. This is used during development phases.

§Examples

  • Complex number support for certain functions
  • Specific algorithm variants
  • Platform-specific optimizations
§

ConvergenceError(String)

Iterative algorithm convergence failure

Thrown when iterative algorithms fail to converge within specified tolerances or iteration limits. Often indicates numerical instability or inappropriate algorithm parameters.

§Examples

  • Newton-Raphson method divergence
  • Series expansion truncation errors
  • Root-finding algorithm failure
  • Integration quadrature non-convergence
§

OverflowError(String)

Numerical overflow - result too large to represent

Occurs when mathematical operations produce results that exceed the representable range of floating-point numbers (typically > 1.8e308 for f64).

§Examples

  • gamma(1000) - extremely large gamma function values
  • exp(1000) - exponential overflow
  • Factorial of large numbers
  • Product operations with many large terms
§

GpuNotAvailable(String)

GPU acceleration unavailable, computation falls back to CPU

Indicates that GPU computation was requested but is not available. This is often a non-fatal error where computation continues on CPU, but can be used to inform users about performance implications.

§Examples

  • No GPU hardware available
  • GPU drivers not installed
  • CUDA/OpenCL runtime unavailable
  • GPU memory exhaustion
§

CoreError(CoreError)

Error propagated from scirs2-core dependency

Wraps errors from the core SciRS2 infrastructure. These typically relate to low-level operations like SIMD, parallel processing, or hardware acceleration.

Trait Implementations§

Source§

impl Debug for SpecialError

Source§

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

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

impl Display for SpecialError

Source§

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

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

impl Error for SpecialError

Source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§

fn description(&self) -> &str

👎Deprecated since 1.42.0: use the Display impl or to_string()
1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
Source§

impl From<CoreError> for SpecialError

Source§

fn from(source: CoreError) -> Self

Converts to this type from the input type.
Source§

impl From<Error> for SpecialError

Convert from standard library IO errors

Automatically converts std::io::Error into SpecialError::ComputationError for handling file I/O failures during computation or data loading.

Source§

fn from(err: Error) -> Self

Converts to this type from the input type.
Source§

impl From<ParseFloatError> for SpecialError

Convert from standard library float parsing errors

Automatically converts ParseFloatError into SpecialError::ValueError for seamless error propagation when parsing numerical input.

Source§

fn from(err: ParseFloatError) -> Self

Converts to this type from the input type.

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

Source§

fn az<Dst>(self) -> Dst
where T: Cast<Dst>,

Casts the value.
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<Src, Dst> CastFrom<Src> for Dst
where Src: Cast<Dst>,

Source§

fn cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<T> CheckedAs for T

Source§

fn checked_as<Dst>(self) -> Option<Dst>
where T: CheckedCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> CheckedCastFrom<Src> for Dst
where Src: CheckedCast<Dst>,

Source§

fn checked_cast_from(src: Src) -> Option<Dst>

Casts the value.
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
Source§

impl<T> OverflowingAs for T

Source§

fn overflowing_as<Dst>(self) -> (Dst, bool)
where T: OverflowingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> OverflowingCastFrom<Src> for Dst
where Src: OverflowingCast<Dst>,

Source§

fn overflowing_cast_from(src: Src) -> (Dst, bool)

Casts the value.
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

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

Initializes a with the given initializer. Read more
Source§

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

Dereferences the given pointer. Read more
Source§

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

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

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

impl<T> SaturatingAs for T

Source§

fn saturating_as<Dst>(self) -> Dst
where T: SaturatingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> SaturatingCastFrom<Src> for Dst
where Src: SaturatingCast<Dst>,

Source§

fn saturating_cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<T> StrictAs for T

Source§

fn strict_as<Dst>(self) -> Dst
where T: StrictCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> StrictCastFrom<Src> for Dst
where Src: StrictCast<Dst>,

Source§

fn strict_cast_from(src: Src) -> Dst

Casts the value.
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> UnwrappedAs for T

Source§

fn unwrapped_as<Dst>(self) -> Dst
where T: UnwrappedCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> UnwrappedCastFrom<Src> for Dst
where Src: UnwrappedCast<Dst>,

Source§

fn unwrapped_cast_from(src: Src) -> Dst

Casts the value.
Source§

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

Source§

fn vzip(self) -> V

Source§

impl<T> WrappingAs for T

Source§

fn wrapping_as<Dst>(self) -> Dst
where T: WrappingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> WrappingCastFrom<Src> for Dst
where Src: WrappingCast<Dst>,

Source§

fn wrapping_cast_from(src: Src) -> Dst

Casts the value.