// Copyright (c) FIRST and other WPILib contributors. // Open Source Software; you can modify and/or share it under the terms of // the WPILib BSD license file in the root directory of this project. package edu.wpi.first.units; import edu.wpi.first.units.measure.Distance; /** * Unit of linear dimension. * *

This is the base type for units of linear dimension. It is also used to specify the dimension * for {@link Measure}: Measure<DistanceUnit>. * *

Actual units (such as {@link Units#Meters} and {@link Units#Inches}) can be found in the * {@link Units} class. */ public final class DistanceUnit extends Unit { DistanceUnit(DistanceUnit baseUnit, double baseUnitEquivalent, String name, String symbol) { super(baseUnit, baseUnitEquivalent, name, symbol); } DistanceUnit( DistanceUnit baseUnit, UnaryFunction toBaseConverter, UnaryFunction fromBaseConverter, String name, String symbol) { super(baseUnit, toBaseConverter, fromBaseConverter, name, symbol); } @Override public DistanceUnit getBaseUnit() { return (DistanceUnit) super.getBaseUnit(); } @Override public LinearVelocityUnit per(TimeUnit period) { return LinearVelocityUnit.combine(this, period); } /** * Creates a ratio unit between this unit and an arbitrary other unit. * * @param other the other unit * @param the type of the other unit * @return the ratio unit */ public PerUnit per(U other) { return PerUnit.combine(this, other); } /** * Converts a measurement value in terms of another distance unit to this unit. * * @param magnitude the magnitude of the measurement in terms of the other distance unit * @param otherUnit the other distance unit * @return the value of the measurement in terms of this unit */ public double convertFrom(double magnitude, DistanceUnit otherUnit) { return fromBaseUnits(otherUnit.toBaseUnits(magnitude)); } @Override public Distance of(double magnitude) { return new Distance(magnitude, toBaseUnits(magnitude), this); } @Override public Distance ofBaseUnits(double baseUnitMagnitude) { return new Distance(fromBaseUnits(baseUnitMagnitude), baseUnitMagnitude, this); } @Override public Distance zero() { return (Distance) super.zero(); } @Override public Distance one() { return (Distance) super.one(); } /** * Multiplies this distance unit by a unit of force to create a unit of torque. * * @param force the unit of force * @return the combined torque unit */ public TorqueUnit multAsTorque(ForceUnit force) { return TorqueUnit.combine(this, force); } // TODO: Add a multAsEnergy equivalent }