Other functions

Error handling · Floating point · Quantities · Chemical elements · Mixed unit conversion · Temperature conversion · Color format conversion

Error handling

Defined in: core::error

error

Throw an error with the specified message. Stops the execution of the program.

fn error<T>(message: String) -> T

Floating point

Defined in: core::numbers

is_nan

Returns true if the input is NaN. More information here.

fn is_nan<T: Dim>(n: T) -> Bool
Examples
is_nan(37) = false [Bool]
is_nan(NaN) = true [Bool]

is_infinite

Returns true if the input is positive infinity or negative infinity. More information here.

fn is_infinite<T: Dim>(n: T) -> Bool
Examples
is_infinite(37) = false [Bool]
is_infinite(-inf) = true [Bool]

is_finite

Returns true if the input is neither infinite nor NaN.

fn is_finite<T: Dim>(n: T) -> Bool
Examples
is_finite(37) = true [Bool]
is_finite(-inf) = false [Bool]

is_zero

Returns true if the input is 0 (zero).

fn is_zero<D: Dim>(value: D) -> Bool
Examples
is_zero(37) = false [Bool]
is_zero(0) = true [Bool]

is_nonzero

Returns true unless the input is 0 (zero).

fn is_nonzero<D: Dim>(value: D) -> Bool
Examples
is_nonzero(37) = true [Bool]
is_nonzero(0) = false [Bool]

is_integer

Returns true if the input is an integer.

fn is_integer(x: Scalar) -> Bool
Examples
is_integer(3) = true [Bool]
is_integer(pi) = false [Bool]

Quantities

Defined in: core::quantities

value_of

Extract the plain value of a quantity (the 20 in 20 km/h). This can be useful in generic code, but should generally be avoided otherwise.

fn value_of<T: Dim>(x: T) -> Scalar
Examples
value_of(20 km/h) = 20

unit_of

Extract the unit of a quantity (the km/h in 20 km/h). This can be useful in generic code, but should generally be avoided otherwise. Returns an error if the quantity is zero.

fn unit_of<T: Dim>(x: T) -> T
Examples
unit_of(20 km/h) = 1 km/h [Velocity]

has_unit

Returns true if quantity has the same unit as unit_query, or if quantity evaluates to zero.

fn has_unit<T: Dim>(quantity: T, unit_query: T) -> Bool
Examples
has_unit(20 km/h, km/h) = true [Bool]
has_unit(20 km/h, m/s) = false [Bool]

is_dimensionless

Returns true if quantity is dimensionless, or if quantity is zero.

fn is_dimensionless<T: Dim>(quantity: T) -> Bool
Examples
is_dimensionless(10) = true [Bool]
is_dimensionless(10 km/h) = false [Bool]

unit_name

Returns a string representation of the unit of quantity. Returns an empty string if quantity is dimensionless.

fn unit_name<T: Dim>(quantity: T) -> String
Examples
unit_name(20) = "" [String]
unit_name(20 m^2) = "m²" [String]
unit_name(20 km/h) = "km/h" [String]

Chemical elements

Defined in: chemistry::elements

element (Chemical element)

Get properties of a chemical element by its symbol or name (case-insensitive).

fn element(pattern: String) -> ChemicalElement
Examples

Get the entire element struct for hydrogen.

element("H") = ChemicalElement { symbol: "H", name: "Hydrogen", atomic_number: 1, group: 1, group_name: "Alkali metals", period: 1, melting_point: 13.99 K, boiling_point: 20.271 K, density: 0.00008988 g/cm³, electron_affinity: 0.754 eV, ionization_energy: 13.598 eV, vaporization_heat: 0.904 kJ/mol } [ChemicalElement]

Get the ionization energy of hydrogen.

element("hydrogen").ionization_energy = 13.598 eV [Energy or Torque]

Mixed unit conversion

Defined in: units::mixed

unit_list (Unit list)

Convert a value to a mixed representation using the provided units.

fn unit_list<D: Dim>(units: List<D>, value: D) -> List<D>
Examples
5500 m |> unit_list([miles, yards, feet, inches]) = [3 mi, 734 yd, 2 ft, 7.43307 in] [List]

DMS (Degrees, minutes, seconds)

Convert an angle to a mixed degrees, (arc)minutes, and (arc)seconds representation. Also called sexagesimal degree notation. More information here.

fn DMS(alpha: Angle) -> List<Angle>
Examples
46.5858° -> DMS = [46°, 35′, 8.88″] [List]

DM (Degrees, decimal minutes)

Convert an angle to a mixed degrees and decimal minutes representation. More information here.

fn DM(alpha: Angle) -> List<Angle>
Examples
46.5858° -> DM = [46°, 35.148′] [List]

feet_and_inches (Feet and inches)

Convert a length to a mixed feet and inches representation. More information here.

fn feet_and_inches(length: Length) -> List<Length>
Examples
180 cm -> feet_and_inches = [5 ft, 10.8661 in] [List]

pounds_and_ounces (Pounds and ounces)

Convert a mass to a mixed pounds and ounces representation. More information here.

fn pounds_and_ounces(mass: Mass) -> List<Mass>
Examples
1 kg -> pounds_and_ounces = [2 lb, 3.27396 oz] [List]

Temperature conversion

Defined in: physics::temperature_conversion

from_celsius

Converts from degree Celsius (°C) to Kelvin. More information here.

fn from_celsius(t_celsius: Scalar) -> Temperature
Examples

300 °C in Kelvin.

from_celsius(300) = 573.15 K [Temperature]

celsius

Converts from Kelvin to degree Celcius (°C). This can be used on the right hand side of a conversion operator: 200 K -> celsius. More information here.

fn celsius(t_kelvin: Temperature) -> Scalar
Examples

300 K in degree Celsius.

300K -> celsius = 26.85

from_fahrenheit

Converts from degree Fahrenheit (°F) to Kelvin. More information here.

fn from_fahrenheit(t_fahrenheit: Scalar) -> Temperature
Examples

300 °F in Kelvin.

from_fahrenheit(300) = 422.039 K [Temperature]

fahrenheit

Converts from Kelvin to degree Fahrenheit (°F). This can be used on the right hand side of a conversion operator: 200 K -> fahrenheit. More information here.

fn fahrenheit(t_kelvin: Temperature) -> Scalar
Examples

300 K in degree Fahrenheit.

300K -> fahrenheit = 80.33

Color format conversion

Defined in: extra::color

rgb

Create a Color from RGB (red, green, blue) values in the range \( [0, 256) \).

fn rgb(red: Scalar, green: Scalar, blue: Scalar) -> Color
Examples
use extra::color rgb(125, 128, 218) = Color { red: 125, green: 128, blue: 218 } [Color]

color

Create a Color from a (hexadecimal) value.

fn color(rgb_hex: Scalar) -> Color
Examples
use extra::color color(0xff7700) = Color { red: 255, green: 119, blue: 0 } [Color]

color_rgb

Convert a color to its RGB representation.

fn color_rgb(color: Color) -> String
Examples
use extra::color cyan -> color_rgb = "rgb(0, 255, 255)" [String]

color_rgb_float

Convert a color to its RGB floating point representation.

fn color_rgb_float(color: Color) -> String
Examples
use extra::color cyan -> color_rgb_float = "rgb(0.000, 1.000, 1.000)" [String]

color_hex

Convert a color to its hexadecimal representation.

fn color_hex(color: Color) -> String
Examples
use extra::color rgb(225, 36, 143) -> color_hex = "#e1248f" [String]