java.lang.Object
java.lang.Enum<Speed>
org.tquadrat.foundation.value.Speed
All Implemented Interfaces:
Serializable, Comparable<Speed>, Constable, Dimension, DimensionWithLinearConversion

@ClassVersion(sourceVersion="$Id: Speed.java 1072 2023-09-30 20:44:38Z tquadrat $") @API(status=STABLE, since="0.0.4") public enum Speed extends Enum<Speed> implements DimensionWithLinearConversion

The various instances of speed …

Because speed is distance per time, the values for factor() are calculated based on the values from Length.factor() and Time.factor().

Author:
Thomas Thrien (thomas.thrien@tquadrat.org)
Version:
$Id: Speed.java 1072 2023-09-30 20:44:38Z tquadrat $
Since:
0.0.4
UML Diagram
UML Diagram for "org.tquadrat.foundation.value.Speed"

UML Diagram for "org.tquadrat.foundation.value.Speed"

UML Diagram for "org.tquadrat.foundation.value.Speed"
  • Enum Constant Details

    • ÅNGSTRÖM_PER_WEEK

      public static final Speed ÅNGSTRÖM_PER_WEEK

      Ångström per Week. This is by far not a useful unit for speed, but it is the implementation of a famous instance of Murphy's Laws:

      "Units are always provided in the most impractical form, e.g. a speed as Ångström per Week."
    • FEET_PER_SECOND

      public static final Speed FEET_PER_SECOND
      Feet per second.
    • KNOT

      public static final Speed KNOT
      Knot (nautical mile per hour).
    • KILOMETER_PER_HOUR

      public static final Speed KILOMETER_PER_HOUR
      Kilometer per hour.
    • METER_PER_SECOND

      public static final Speed METER_PER_SECOND
      Meter per second.
    • MILE_PER_HOUR

      public static final Speed MILE_PER_HOUR
      Mile per hour.
  • Field Details

  • Constructor Details

    • Speed

      private Speed(BigDecimal factor, String unitSymbol)
      Creates a new Speed instance.
      Parameters:
      factor - The factor.
      unitSymbol - The unit symbol.
  • Method Details

    • values

      public static Speed[] values()
      Returns an array containing the constants of this enum class, in the order they are declared.
      Returns:
      an array containing the constants of this enum class, in the order they are declared
    • valueOf

      public static Speed valueOf(String name)
      Returns the enum constant of this class with the specified name. The string must match exactly an identifier used to declare an enum constant in this class. (Extraneous whitespace characters are not permitted.)
      Parameters:
      name - the name of the enum constant to be returned.
      Returns:
      the enum constant with the specified name
      Throws:
      IllegalArgumentException - if this enum class has no constant with the specified name
      NullPointerException - if the argument is null
    • baseUnit

      public final Speed baseUnit()

      Returns the base unit.

      E.g. for length, the base unit would be Meter (m), for mass, it is Kilogram (kg), and so on.

      Specified by:
      baseUnit in interface Dimension
      Returns:
      The base unit.
    • factor

      public final BigDecimal factor()

      Returns the factor that is used to convert a value from this unit to the base unit.

      For length, if you have to convert a Centimeter value to Meter, you will divide that by 100 or multiply it with a factor of 0.01.

      For the base unit, the factor is 1.0.

      Specified by:
      factor in interface DimensionWithLinearConversion
      Returns:
      The factor.
      See Also:
    • forUnit

      public static final Speed forUnit(String unitSymbol) throws IllegalArgumentException
      Returns the Speed instance for the given unit.
      Parameters:
      unitSymbol - The unit symbol.
      Returns:
      The respective instance.
      Throws:
      IllegalArgumentException - The given unit is unknown.
    • unitSymbol

      public final String unitSymbol()

      Returns the unit symbol for the dimension as a single line string.

      For a length, this would be "m", for a speed "km/h", and for an acceleration, it could be "m/(s^2)".

      Specified by:
      unitSymbol in interface Dimension
      Returns:
      The unit.