spire.algebra.CoordinateSpace.scala Maven / Gradle / Ivy
package spire.algebra
import spire.std._
import scala.{ specialized => spec }
import scala.collection.SeqLike
import scala.collection.generic.CanBuildFrom
import scala.reflect.ClassTag
import scala.annotation.tailrec
trait CoordinateSpace[V, @spec(Float, Double) F] extends Any with InnerProductSpace[V, F] {
def dimensions: Int
def coord(v: V, i: Int): F // = v dot axis(i)
def axis(i: Int): V
def _x(v: V): F = coord(v, 0)
def _y(v: V): F = coord(v, 1)
def _z(v: V): F = coord(v, 2)
def basis: Vector[V] = Vector.tabulate(dimensions)(axis)
def dot(v: V, w: V): F = {
@tailrec def loop(sum: F, i: Int): F = if (i < dimensions) {
loop(scalar.plus(sum, scalar.times(coord(v, i), coord(w, i))), i + 1)
} else {
sum
}
loop(scalar.zero, 0)
}
}
object CoordinateSpace {
@inline final def apply[V, @spec(Float,Double) F](implicit V: CoordinateSpace[V, F]): CoordinateSpace[V, F] = V
def seq[A: Field, CC[A] <: SeqLike[A, CC[A]]](dimensions: Int)(implicit
cbf0: CanBuildFrom[CC[A], A, CC[A]]): SeqCoordinateSpace[A, CC[A]] = new SeqCoordinateSpace[A, CC[A]](dimensions)
def array[@spec(Float, Double) A: Field: ClassTag](dimensions: Int): CoordinateSpace[Array[A], A] =
new ArrayCoordinateSpace[A](dimensions)
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy