1
0
mirror of https://github.com/DanilaFe/abacus synced 2024-11-04 18:08:31 -08:00
Abacus/src/main/java/org/nwapw/abacus/number/NumberInterface.java

178 lines
5.0 KiB
Java
Raw Normal View History

package org.nwapw.abacus.number;
2017-07-25 22:47:48 -07:00
/**
* An interface used to represent a number.
*/
public abstract class NumberInterface {
/**
* Check if the thread was interrupted and
* throw an exception to end the computation.
*/
private static void checkInterrupted(){
if(Thread.currentThread().isInterrupted())
throw new ComputationInterruptedException();
}
2017-07-25 22:47:48 -07:00
/**
* The maximum precision to which this number operates.
2017-07-30 21:11:32 -07:00
*
2017-07-25 22:47:48 -07:00
* @return the precision.
*/
public abstract int getMaxPrecision();
2017-07-25 22:47:48 -07:00
/**
* Multiplies this number by another, returning
* a new number instance.
2017-07-30 21:11:32 -07:00
*
2017-07-25 22:47:48 -07:00
* @param multiplier the multiplier
* @return the result of the multiplication.
*/
protected abstract NumberInterface multiplyInternal(NumberInterface multiplier);
public final NumberInterface multiply(NumberInterface multiplier){
checkInterrupted();
return multiplyInternal(multiplier);
}
2017-07-30 21:11:32 -07:00
2017-07-25 22:47:48 -07:00
/**
* Divides this number by another, returning
* a new number instance.
2017-07-30 21:11:32 -07:00
*
2017-07-25 22:47:48 -07:00
* @param divisor the divisor
* @return the result of the division.
*/
protected abstract NumberInterface divideInternal(NumberInterface divisor);
public final NumberInterface divide(NumberInterface divisor){
checkInterrupted();
return divideInternal(divisor);
}
2017-07-30 21:11:32 -07:00
2017-07-25 22:47:48 -07:00
/**
* Adds this number to another, returning
* a new number instance.
2017-07-30 21:11:32 -07:00
*
2017-07-25 22:47:48 -07:00
* @param summand the summand
* @return the result of the summation.
*/
protected abstract NumberInterface addInternal(NumberInterface summand);
public final NumberInterface add(NumberInterface summand){
checkInterrupted();
return addInternal(summand);
}
2017-07-30 21:11:32 -07:00
2017-07-25 22:47:48 -07:00
/**
* Subtracts another number from this number,
* a new number instance.
2017-07-30 21:11:32 -07:00
*
2017-07-25 22:47:48 -07:00
* @param subtrahend the subtrahend.
* @return the result of the subtraction.
*/
protected abstract NumberInterface subtractInternal(NumberInterface subtrahend);
public final NumberInterface subtract(NumberInterface subtrahend){
checkInterrupted();
return subtractInternal(subtrahend);
}
2017-07-25 22:47:48 -07:00
/**
* Returns a new instance of this number with
* the sign flipped.
2017-07-30 21:11:32 -07:00
*
2017-07-25 22:47:48 -07:00
* @return the new instance.
*/
protected abstract NumberInterface negateInternal();
public final NumberInterface negate(){
checkInterrupted();
return negateInternal();
}
2017-07-25 22:47:48 -07:00
/**
* Raises this number to an integer power.
2017-07-30 21:11:32 -07:00
*
2017-07-26 19:28:57 -07:00
* @param exponent the exponent to which to take the number.
* @return the resulting value.
2017-07-25 22:47:48 -07:00
*/
protected abstract NumberInterface intPowInternal(int exponent);
public final NumberInterface intPow(int exponent){
checkInterrupted();
return intPowInternal(exponent);
}
2017-07-25 22:47:48 -07:00
/**
* Compares this number to another.
2017-07-30 21:11:32 -07:00
*
2017-07-25 22:47:48 -07:00
* @param number the number to compare to.
* @return same as Integer.compare();
*/
public abstract int compareTo(NumberInterface number);
2017-07-25 22:47:48 -07:00
/**
* Same as Math.signum().
2017-07-30 21:11:32 -07:00
*
2017-07-25 22:47:48 -07:00
* @return 1 if this number is positive, -1 if this number is negative, 0 if this number is 0.
*/
public abstract int signum();
/**
* Returns the least integer greater than or equal to the number.
2017-08-04 13:20:57 -07:00
*
* @return the least integer >= the number, if int can hold the value.
*/
protected abstract NumberInterface ceilingInternal();
public final NumberInterface ceiling(){
checkInterrupted();
return ceilingInternal();
}
/**
* Return the greatest integer less than or equal to the number.
2017-08-04 13:20:57 -07:00
*
* @return the greatest int >= the number, if int can hold the value.
*/
protected abstract NumberInterface floorInternal();
public final NumberInterface floor(){
checkInterrupted();
return floorInternal();
}
/**
* Returns the fractional part of the number.
2017-08-04 13:20:57 -07:00
*
* @return the fractional part of the number.
*/
protected abstract NumberInterface fractionalPartInternal();
public final NumberInterface fractionalPart(){
checkInterrupted();
return fractionalPartInternal();
}
/**
* Returns the integer representation of this number, discarding any fractional part,
* if int can hold the value.
2017-08-04 13:20:57 -07:00
*
* @return
*/
public abstract int intValue();
2017-07-25 22:47:48 -07:00
/**
* Promotes this class to another number class.
2017-07-30 21:11:32 -07:00
*
2017-07-25 22:47:48 -07:00
* @param toClass the class to promote to.
* @return the resulting new instance.
*/
protected abstract NumberInterface promoteToInternal(Class<? extends NumberInterface> toClass);
public final NumberInterface promoteTo(Class<? extends NumberInterface> toClass) {
checkInterrupted();
return promoteToInternal(toClass);
}
}