approx
approx
Returns the absolute value of this Quantity
Returns boolean result of approximate equality comparison
Returns boolean result of approximate equality comparison
Quantity
Quantity
Returns the smallest (closest to negative infinity) Quantity value that is greater than or equal to the argument and is equal to a mathematical integer.
Returns the smallest (closest to negative infinity) Quantity value that is greater than or equal to the argument and is equal to a mathematical integer.
Quantity
java.lang.Math#ceil(double)
Implements Ordered.
The Dimension this quantity represents
Divide this quantity by a like quantity
Divide this quantity by some number
Returns a Pair that includes the result of divideToInteger and remainder
Returns a Pair that includes the result of divideToInteger and remainder
Quantity
(Double, Quantity)
Returns a Pair that includes the result of divideToInteger and remainder
Returns a Pair that includes the result of divideToInteger and remainder
Double
(Quantity, Quantity)
Override of equals method
Override of equals method
must be of matching value and unit
Returns the largest (closest to positive infinity) Quantity value that is less than or equal to the argument and is equal to a mathematical integer
Returns the largest (closest to positive infinity) Quantity value that is less than or equal to the argument and is equal to a mathematical integer
Quantity
java.lang.Math#floor(double)
Override of hashCode
Returns an equivalent Quantity boxed with the supplied Unit
Returns an equivalent Quantity boxed with the supplied Unit
UnitOfMeasure[A]
Quantity
Applies a function to the underlying value of the Quantity, returning a new Quantity in the same unit
Applies a function to the underlying value of the Quantity, returning a new Quantity in the same unit
Double => Double function
Returns the max of this and that Quantity
Returns the min of this and that Quantity
Subtract two like quantities
Returns the negative value of this Quantity
Returns true if this value is not within (contains) the range
Returns true if this value is not within (contains) the range
QuantityRange
Boolean
Add two like quantities
Returns a QuantityRange representing the range for this value +- that
Returns a QuantityRange representing the range for this value +- that
Quantity
QuantityRange
Returns the remainder of a division by a like quantity
Returns the remainder of a division by a like quantity
Quantity
Double
Returns the remainder of a division by a number
Returns the remainder of a division by a number
Quantity
Quantity
Returns the Quantity value that is closest in value to the argument and is equal to a mathematical integer.
Returns the Quantity value that is closest in value to the argument and is equal to a mathematical integer.
Quantity
java.lang.Math#rint(double)
Multiply this quantity by some number
Returns a Double representing the quantity in terms of the supplied unit
Returns a Double representing the quantity in terms of the supplied unit
val d = Feet(3) (d to Inches) should be(36)
UnitOfMeasure[A]
Double
Returns a QuantityRange that goes from this to that
Returns a QuantityRange that goes from this to that
Quantity
QuantityRange
Returns a string representing the quantity's value in unit
Returns a string representing the quantity's value in unit
String
Returns a string representing the quantity's value in the given unit
in the given format
Returns a string representing the quantity's value in the given unit
in the given format
UnitOfMeasure[A] with UnitConverter
String containing the format for the value (ie "%.3f")
String
Returns a string representing the quantity's value in the given unit
Returns a string representing the quantity's value in the given unit
UnitOfMeasure[A] with UnitConverter
String
Returns a pair representing the numeric value and the uom's symbol
Returns a pair representing the numeric value and the uom's symbol
UnitOfMeasure[A]
Returns a tuple representing the numeric value and the unit's symbol
Returns a tuple representing the numeric value and the unit's symbol
The Unit of Measure the value represents
The Unit of Measure the value represents
UnitOfMeasure[A]
the value of the temperature
the value of the temperature
Returns true if this value is within (contains) the range
Returns true if this value is within (contains) the range
QuantityRange
Boolean
approx
approx
approx
approx
Represents a quantity of temperature
Temperatures are somewhat unique in the world of quantities for a couple of reasons.
First, different units (scales) have different "zero" values. This means that these scales are not simple multiples of the others. There is a "zero offset" that must be applied to conversions from one scale to another.
Second, temperatures are often quoted as though they were quantities, when in fact they are just points on a scale. Similar to a mile marker on a highway, the quantity represented is the number degrees (miles) from a specific "zero" value on the scale.
In fact an absolute quantity of thermodynamic temperature should be measured from absolute zero. Thus, Kelvin, is the SI Base unit for temperature.
The other scales supported here, Celsius and Fahrenheit, are known as empirical scales. Of course, these scales set their respective zero values well above absolute zero. This is done to provide a granular and reasonably sized ranges of values for dealing with everyday temperatures.
This library supports another absolute scale, the Rankine scale. Rankine sets its zero at absolute zero, but degrees are measure in Fahrenheit (as opposed to Celsius, as the Kelvin scale uses).
In consideration of these more unique scale conversions, two conversion types are supported: Degrees and Scale.
Scale based conversions DO adjust for the zero offset. Thus 5 degrees C is the same as 41 degrees F on the thermometer.
Degrees based conversions DO NOT adjust for the zero point. Thus 5 degrees C|K is the same amount of temperature as 9 degrees F|R.
When creating a temperature it is not important to consider these differences. It is also irrelevant when performing operation on temperatures in the same scale. However, when performing operations on two temperatures of different scales these factors do become important.
The Quantity.to(unit) and Quantity.in(unit) methods are overridden to use Scale conversions for convenience
The Ordered.compare method is implemented to use Scale conversions
The Quantity.plus and Quantity.minus methods are implemented to treat right operands as Quantity of Degrees and not a scale Temperature. Operands that differ in scale will use Degree conversions. This supports mixed scale expressions:
val temp = Fahrenheit(100) - Celsius(5) // returns Fahrenheit(91)
This also supports declaring temperature ranges using typical nomenclature:
val tempRange = 65.F +- 5.C // returns QuantityRange(56.0°F,74.0°F)
The toDegrees(unit) methods are implemented to use Degree conversions.
0.1