Class ProductUnit<Q extends Quantity>

All Implemented Interfaces:
Serializable

public final class ProductUnit<Q extends Quantity> extends DerivedUnit<Q>

This class represents units formed by the product of rational powers of existing units.

This class maintains the canonical form of this product (simplest form after factorization). For example: METER.pow(2).divide(METER) returns METER.

See Also:
  • Constructor Details

    • ProductUnit

      public ProductUnit(Unit<?> productUnit)
      Copy constructor (allows for parameterization of product units).
      Parameters:
      productUnit - the product unit source.
      Throws:
      ClassCastException - if the specified unit is not a product unit.
  • Method Details

    • getUnitCount

      public int getUnitCount()
      Returns the number of units in this product.
      Returns:
      the number of units being multiplied.
    • getUnit

      public Unit<? extends Quantity> getUnit(int index)
      Returns the unit at the specified position.
      Parameters:
      index - the index of the unit to return.
      Returns:
      the unit at the specified position.
      Throws:
      IndexOutOfBoundsException - if index is out of range (index < 0 || index >= size()).
    • getUnitPow

      public int getUnitPow(int index)
      Returns the power exponent of the unit at the specified position.
      Parameters:
      index - the index of the unit to return.
      Returns:
      the unit power exponent at the specified position.
      Throws:
      IndexOutOfBoundsException - if index is out of range (index < 0 || index >= size()).
    • getUnitRoot

      public int getUnitRoot(int index)
      Returns the root exponent of the unit at the specified position.
      Parameters:
      index - the index of the unit to return.
      Returns:
      the unit root exponent at the specified position.
      Throws:
      IndexOutOfBoundsException - if index is out of range (index < 0 || index >= size()).
    • equals

      public boolean equals(Object that)
      Indicates if this product unit is considered equals to the specified object.
      Specified by:
      equals in class Unit<Q extends Quantity>
      Parameters:
      that - the object to compare for equality.
      Returns:
      true if this and that are considered equals; falseotherwise.
    • hashCode

      public int hashCode()
      Description copied from class: Unit
      Returns the hash code for this unit.
      Specified by:
      hashCode in class Unit<Q extends Quantity>
      Returns:
      this unit hashcode value.
    • getStandardUnit

      public Unit<? super Q> getStandardUnit()
      Description copied from class: Unit
      Returns the base unit, alternate unit or product of base units and alternate units this unit is derived from. The standard unit identifies the "type" of quantity for which this unit is employed. For example:[code] boolean isAngularVelocity(Unit<?> u) { return u.getStandardUnit().equals(RADIAN.divide(SECOND)); } assert(REVOLUTION.divide(MINUTE).isAngularVelocity()); [/code]

      Note: Having the same system unit is not sufficient to ensure that a converter exists between the two units (e.g. °C/m and K/m).

      Specified by:
      getStandardUnit in class Unit<Q extends Quantity>
      Returns:
      the system unit this unit is derived from.
    • toStandardUnit

      public UnitConverter toStandardUnit()
      Description copied from class: Unit
      Returns the converter from this unit to its system unit.
      Specified by:
      toStandardUnit in class Unit<Q extends Quantity>
      Returns:
      this.getConverterTo(this.getSystemUnit())