spire.std.int.scala Maven / Gradle / Ivy
package spire.std
import spire.algebra.{EuclideanRing, IsIntegral, NRoot, Order, Signed}
import spire.math.BitString
import java.lang.Math
import java.lang.Integer
trait IntIsEuclideanRing extends EuclideanRing[Int] {
override def minus(a:Int, b:Int): Int = a - b
def negate(a:Int): Int = -a
def one: Int = 1
def plus(a:Int, b:Int): Int = a + b
override def pow(a:Int, b:Int): Int = spire.math.pow(a, b).toInt
override def times(a:Int, b:Int): Int = a * b
def zero: Int = 0
override def fromInt(n: Int): Int = n
def quot(a:Int, b:Int): Int = a / b
def mod(a:Int, b:Int): Int = a % b
def gcd(a:Int, b:Int): Int = spire.math.gcd(a, b).toInt
}
// Not included in Instances trait.
trait IntIsNRoot extends NRoot[Int] {
def nroot(x: Int, n: Int): Int = {
def findnroot(prev: Int, add: Int): Int = {
val next = prev | add
val e = Math.pow(next, n)
if (e == x || add == 0) {
next
} else if (e <= 0 || e > x) {
findnroot(prev, add >> 1)
} else {
findnroot(next, add >> 1)
}
}
findnroot(0, 1 << ((33 - n) / n))
}
def log(a:Int): Int = Math.log(a.toDouble).toInt
def fpow(a:Int, b:Int): Int = Math.pow(a, b).toInt
}
trait IntOrder extends Order[Int] {
override def eqv(x: Int, y: Int): Boolean = x == y
override def neqv(x: Int, y: Int): Boolean = x != y
override def gt(x: Int, y: Int): Boolean = x > y
override def gteqv(x: Int, y: Int): Boolean = x >= y
override def lt(x: Int, y: Int): Boolean = x < y
override def lteqv(x: Int, y: Int): Boolean = x <= y
def compare(x: Int, y: Int): Int = if (x < y) -1 else if (x == y) 0 else 1
}
trait IntIsSigned extends Signed[Int] {
def signum(a: Int): Int = java.lang.Integer.signum(a)
def abs(a: Int): Int = if (a < 0) -a else a
}
trait IntIsReal extends IsIntegral[Int] with IntOrder with IntIsSigned {
def toDouble(n: Int): Double = n.toDouble
def toBigInt(n: Int): BigInt = BigInt(n)
}
@SerialVersionUID(0L)
class IntIsBitString extends BitString[Int] with Serializable {
def one: Int = -1
def zero: Int = 0
def and(a: Int, b: Int): Int = a & b
def or(a: Int, b: Int): Int = a | b
def complement(a: Int): Int = ~a
override def xor(a: Int, b: Int): Int = a ^ b
def signed: Boolean = true
def width: Int = 32
def toHexString(n: Int): String = Integer.toHexString(n)
def bitCount(n: Int): Int = Integer.bitCount(n)
def highestOneBit(n: Int): Int = Integer.highestOneBit(n)
def lowestOneBit(n: Int): Int = Integer.lowestOneBit(n)
def numberOfLeadingZeros(n: Int): Int = Integer.numberOfLeadingZeros(n)
def numberOfTrailingZeros(n: Int): Int = Integer.numberOfTrailingZeros(n)
def leftShift(n: Int, i: Int): Int = n << i
def rightShift(n: Int, i: Int): Int = n >>> i
def signedRightShift(n: Int, i: Int): Int = n >> i
def rotateLeft(n: Int, i: Int): Int = Integer.rotateLeft(n, i)
def rotateRight(n: Int, i: Int): Int = Integer.rotateRight(n, i)
}
@SerialVersionUID(0L)
class IntAlgebra extends IntIsEuclideanRing with IntIsNRoot with IntIsReal with Serializable
trait IntInstances {
implicit final val IntBitString = new IntIsBitString
implicit final val IntAlgebra = new IntAlgebra
import spire.math.NumberTag._
implicit final val IntTag = new BuiltinIntTag[Int](0, Int.MinValue, Int.MaxValue)
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy