TypedDoubleScalarRel.java
package org.djunits.value.vdouble.scalar;
import org.djunits.unit.Unit;
/**
* Absolute Relative typed scalar. <br>
* Note: Each scalar class should implement the static interpolate(zero, one, ratio). <br>
* Note: A scalar class can implement the toAbs() method if it has an absolute equivalent.
* <p>
* Copyright (c) 2013-2016 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved. <br>
* BSD-style license. See <a href="http://djunits.org/docs/license.html">DJUNITS License</a>.
* <p>
* $LastChangedDate: 2015-10-04 20:45:14 +0200 (Sun, 04 Oct 2015) $, @version $Revision: 85 $, by $Author: averbraeck $, initial
* version Sep 5, 2015 <br>
* @author <a href="http://www.tbm.tudelft.nl/averbraeck">Alexander Verbraeck</a>
* @author <a href="http://www.tudelft.nl/pknoppers">Peter Knoppers</a>
* @param <U> the unit
* @param <R> the relative vector type
*/
public abstract class TypedDoubleScalarRel<U extends Unit<U>, R extends TypedDoubleScalarRel<U, R>> extends DoubleScalar.Rel<U>
{
/** */
private static final long serialVersionUID = 20150905L;
/**
* Construct Rel scalar.
* @param value double value
* @param unit unit for the double value
*/
public TypedDoubleScalarRel(final double value, final U unit)
{
super(value, unit);
}
/**
* Construct Rel scalar.
* @param value Scalar from which to construct this instance
*/
public TypedDoubleScalarRel(final R value)
{
super(value);
}
/**
* Construct a new Relative Immutable DoubleScalar of the right type. Each extending class must implement this method.
* @param value the double value
* @param unit the unit
* @return R a new relative instance of the DoubleScalar of the right type
*/
protected abstract R instantiateTypeRel(final double value, final U unit);
/* Note: Each scalar class should implement the static interpolate(zero, one, ratio). */
/* Note: A scalar class can implement the toAbs() method if it has an absolute equivalent. */
/** {@inheritDoc} */
@Override
public final R abs()
{
return instantiateTypeRel(Math.abs(getInUnit()), getUnit());
}
/** {@inheritDoc} */
@Override
public final R ceil()
{
return instantiateTypeRel(Math.ceil(getInUnit()), getUnit());
}
/** {@inheritDoc} */
@Override
public final R floor()
{
return instantiateTypeRel(Math.floor(getInUnit()), getUnit());
}
/** {@inheritDoc} */
@Override
public final R rint()
{
return instantiateTypeRel(Math.rint(getInUnit()), getUnit());
}
/** {@inheritDoc} */
@Override
public final R round()
{
return instantiateTypeRel(Math.round(getInUnit()), getUnit());
}
/** {@inheritDoc} */
@Override
public final R multiplyBy(final double factor)
{
return instantiateTypeRel(getInUnit() * factor, getUnit());
}
/** {@inheritDoc} */
@Override
public final R divideBy(final double divisor)
{
return instantiateTypeRel(getInUnit() / divisor, getUnit());
}
/**
* Relative scalar plus Relative scalar = Relative scalar.
* @param v the value to add
* @return sum of this value and v as a new object
*/
public final R plus(final R v)
{
return getUnit().equals(v.getUnit()) ? instantiateTypeRel(getInUnit() + v.getInUnit(), getUnit()) : instantiateTypeRel(
this.si + v.si, getUnit().getStandardUnit());
}
/**
* Relative scalar minus Relative scalar = Relative scalar.
* @param v the value to subtract
* @return difference of this value and v as a new object
*/
public final R minus(final R v)
{
return getUnit().equals(v.getUnit()) ? instantiateTypeRel(getInUnit() - v.getInUnit(), getUnit()) : instantiateTypeRel(
this.si - v.si, getUnit().getStandardUnit());
}
}