Skip to main content

Rational

Struct Rational 

Source
pub struct Rational { /* private fields */ }
Expand description

A normalized exact rational number.

Implementations§

Source§

impl Rational

Source

pub const fn from_integer(value: i128) -> Self

Returns the exact integer value / 1.

Source

pub const fn zero() -> Self

Returns 0 / 1.

Source

pub const fn one() -> Self

Returns 1 / 1.

Source

pub fn try_new( numerator: i128, denominator: i128, ) -> Result<Self, RationalError>

Creates a normalized rational number from a numerator and denominator.

§Errors

Returns RationalError::ZeroDenominator when denominator == 0, and returns overflow-related errors when canonical sign normalization cannot be represented in the current integer type.

§Examples
use use_rational::{Rational, RationalError};

let rational = Rational::try_new(2, 4)?;
assert_eq!(rational, Rational::try_new(1, 2)?);

assert!(matches!(
    Rational::try_new(1, 0),
    Err(RationalError::ZeroDenominator)
));
Source

pub const fn numerator(&self) -> i128

Returns the normalized numerator.

Source

pub const fn denominator(&self) -> i128

Returns the normalized positive denominator.

Source

pub const fn is_integer(&self) -> bool

Returns true when the rational is an integer.

Source

pub const fn to_integer(self) -> Option<i128>

Returns the exact integer value when the rational is integral.

Source

pub fn reciprocal(self) -> Result<Self, RationalError>

Returns the reciprocal when the rational is non-zero.

§Errors

Returns RationalError::DivisionByZero when self == 0.

Source

pub fn checked_add(self, other: Self) -> Result<Self, RationalError>

Adds two rational numbers exactly.

§Errors

Returns RationalError::ArithmeticOverflow when the intermediate or normalized result cannot be represented exactly.

Source

pub fn checked_sub(self, other: Self) -> Result<Self, RationalError>

Subtracts two rational numbers exactly.

§Errors

Returns RationalError::ArithmeticOverflow when the intermediate or normalized result cannot be represented exactly.

Source

pub fn checked_mul(self, other: Self) -> Result<Self, RationalError>

Multiplies two rational numbers exactly.

§Errors

Returns RationalError::ArithmeticOverflow when the intermediate or normalized result cannot be represented exactly.

Source

pub fn checked_div(self, other: Self) -> Result<Self, RationalError>

Divides two rational numbers exactly.

§Errors

Returns RationalError::DivisionByZero when other == 0, and returns RationalError::ArithmeticOverflow when the exact result cannot be represented.

Source

pub fn as_f64(&self) -> f64

Returns the rational as an approximate f64.

Trait Implementations§

Source§

impl Clone for Rational

Source§

fn clone(&self) -> Rational

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 Rational

Source§

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

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

impl Display for Rational

Source§

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

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

impl PartialEq for Rational

Source§

fn eq(&self, other: &Rational) -> 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 Copy for Rational

Source§

impl Eq for Rational

Source§

impl StructuralPartialEq for Rational

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> 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.