Packages

  • package root
    Definition Classes
    root
  • package lamp

    Lamp provides utilities to build state of the art machine learning applications

    Lamp provides utilities to build state of the art machine learning applications

    Overview

    Notable types and packages:

    • lamp.STen is a memory managed wrapper around aten.ATen, an off the heap, native n-dimensionl array backed by libtorch.
    • lamp.autograd implements reverse mode automatic differentiation.
    • lamp.nn contains neural network building blocks, see e.g. lamp.nn.Linear.
    • lamp.data.IOLoops implements a training loop and other data related abstractions.
    • lamp.knn implements k-nearest neighbor search on the CPU and GPU
    • lamp.umap.Umap implements the UMAP dimension reduction algorithm
    • lamp.onnx implements serialization of computation graphs into ONNX format
    • lamp.io contains CSV and NPY readers
    How to get data into lamp

    Use one of the file readers in lamp.io or one of the factories in lamp.STen$.

    How to define a custom neural network layer

    See the documentation on lamp.nn.GenericModule

    How to compose neural network layers

    See the documentation on lamp.nn

    How to train models

    See the training loops in lamp.data.IOLoops

    Definition Classes
    root
  • package data
    Definition Classes
    lamp
  • CPU
  • CudaDevice
  • Device
  • DoublePrecision
  • FloatingPointPrecision
  • HalfPrecision
  • Movable
  • STen
  • STenOptions
  • Scope
  • SinglePrecision
  • TensorHelpers

object STen extends Serializable

Companion object of lamp.STen

Linear Supertypes
Serializable, Serializable, AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. STen
  2. Serializable
  3. Serializable
  4. AnyRef
  5. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Type Members

  1. implicit class OwnedSyntax extends AnyRef

Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. def addOut(out: STen, self: STen, other: STen, alpha: Double): Unit
  5. def addcmulOut(out: STen, self: STen, tensor1: STen, tensor2: STen, alpha: Double): Unit
  6. def addmmOut(out: STen, self: STen, mat1: STen, mat2: STen, beta: Double, alpha: Double): Unit
  7. def arange[S](start: Double, end: Double, step: Double, tensorOptions: STenOptions = STen.dOptions)(implicit arg0: Sc[S]): STen
  8. def arange_l[S](start: Long, end: Long, step: Long, tensorOptions: STenOptions = STen.lOptions)(implicit arg0: Sc[S]): STen
  9. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  10. def atan2[S](y: STen, x: STen)(implicit arg0: Sc[S]): STen
  11. def bmmOut(out: STen, self: STen, other: STen): Unit
  12. def cat[S](tensors: Seq[STen], dim: Long)(implicit arg0: Sc[S]): STen
  13. def catOut(out: STen, tensors: Seq[STen], dim: Int): Unit
  14. def clone(): AnyRef
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... ) @native()
  15. val dOptions: STenOptions

    A tensor option specifying CPU and double

  16. def divOut(out: STen, self: STen, other: STen): Unit
  17. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  18. def equals(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  19. def eye[S](n: Int, m: Int, tensorOptions: STenOptions)(implicit arg0: Sc[S]): STen
  20. def eye[S](n: Int, tensorOptions: STenOptions = STen.dOptions)(implicit arg0: Sc[S]): STen
  21. val fOptions: STenOptions

    A tensor option specifying CPU and float

  22. def finalize(): Unit
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  23. def free(value: Tensor): STen

    Wraps a tensor without registering it to any scope.

    Wraps a tensor without registering it to any scope.

    Memory may leak.

  24. def fromDoubleArray[S](ar: Array[Double], dim: Seq[Long], device: Device, precision: FloatingPointPrecision)(implicit arg0: Sc[S]): STen

    Returns a tensor with the given content and shape on the given device

  25. def fromFile[S](path: String, offset: Long, length: Long, scalarTypeByte: Byte, pin: Boolean)(implicit arg0: Sc[S]): STen

    Create tensor directly from file.

    Create tensor directly from file. Memory maps a file into host memory. Data is not passed through the JVM. Returned tensor is always on the CPU device.

    path

    file path

    offset

    byte offset into the file. Must be page aligned (usually multiple of 4096)

    length

    byte length of the data

    scalarTypeByte

    scalar type (long=4,half=5,float=6,double=7)

    pin

    if true the mapped segment will be page locked with mlock(2)

    returns

    tensor on CPU

  26. def fromFloatArray[S](ar: Array[Float], dim: Seq[Long], device: Device)(implicit arg0: Sc[S]): STen

    Returns a tensor with the given content and shape on the given device

  27. def fromLongArray[S](ar: Array[Long])(implicit arg0: Sc[S]): STen

    Returns a tensor with the given content and shape on the given device

  28. def fromLongArray[S](ar: Array[Long], dim: Seq[Long], device: Device)(implicit arg0: Sc[S]): STen

    Returns a tensor with the given content and shape on the given device

  29. final def getClass(): Class[_]
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  30. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  31. def indexSelectOut(out: STen, self: STen, dim: Int, index: STen): Unit
  32. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  33. def l1_loss_backward[S](gradOutput: STen, self: STen, target: STen, reduction: Long)(implicit arg0: Sc[S]): STen
  34. val lOptions: STenOptions

    A tensor option specifying CPU and long

  35. def linspace[S](start: Double, end: Double, steps: Long, tensorOptions: STenOptions = STen.dOptions)(implicit arg0: Sc[S]): STen
  36. def lstsq[S](A: STen, B: STen)(implicit arg0: Sc[S]): (STen, STen, STen, STen)
  37. def meanOut(out: STen, self: STen, dim: Seq[Int], keepDim: Boolean): Unit
  38. def mmOut(out: STen, self: STen, other: STen): Unit
  39. def mse_loss[S](self: STen, target: STen, reduction: Long)(implicit arg0: Sc[S]): STen
  40. def mse_loss_backward[S](gradOutput: STen, self: STen, target: STen, reduction: Long)(implicit arg0: Sc[S]): STen
  41. def mulOut(out: STen, self: STen, other: STen): Unit
  42. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  43. def normal[S](mean: Double, std: Double, size: Seq[Long], options: STenOptions)(implicit arg0: Sc[S]): STen
  44. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  45. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  46. def ones[S](size: Seq[Long], tensorOptions: STenOptions = STen.dOptions)(implicit arg0: Sc[S]): STen
  47. def onesLike[S](tensor: STen)(implicit arg0: Sc[S]): STen
  48. def onesLike[S](tensor: Tensor)(implicit arg0: Sc[S]): STen
  49. def owned(value: Tensor)(implicit scope: Scope): STen

    Wraps an aten.Tensor and registering it to the given scope

  50. def powOut(out: STen, self: STen, other: STen): Unit
  51. def powOut(out: STen, self: STen, other: Double): Unit
  52. def rand[S](size: Seq[Long], tensorOptions: STenOptions = STen.dOptions)(implicit arg0: Sc[S]): STen
  53. def randint[S](low: Long, high: Long, size: Seq[Long], tensorOptions: STenOptions)(implicit arg0: Sc[S]): STen
  54. def randint[S](high: Long, size: Seq[Long], tensorOptions: STenOptions = STen.dOptions)(implicit arg0: Sc[S]): STen
  55. def randn[S](size: Seq[Long], tensorOptions: STenOptions = STen.dOptions)(implicit arg0: Sc[S]): STen
  56. def randperm[S](n: Long, tensorOptions: STenOptions = STen.dOptions)(implicit arg0: Sc[S]): STen
  57. def remainderOut(out: STen, self: STen, other: Double): Unit
  58. def remainderOut(out: STen, self: STen, other: STen): Unit
  59. def scalarDouble[S](value: Double, options: STenOptions)(implicit arg0: Sc[S]): STen
  60. def scalarLong(value: Long, options: STenOptions)(implicit scope: Scope): STen
  61. def softplus_backward[S](gradOutput: STen, self: STen, beta: Double, threshold: Double, output: STen)(implicit arg0: Sc[S]): STen
  62. def sparse_coo[S](indices: STen, values: STen, dim: Seq[Long], tensorOptions: STenOptions = STen.dOptions)(implicit arg0: Sc[S]): STen
  63. def stack[S](tensors: Seq[STen], dim: Long)(implicit arg0: Sc[S]): STen
  64. def subOut(out: STen, self: STen, other: STen, alpha: Double): Unit
  65. def sumOut(out: STen, self: STen, dim: Seq[Int], keepDim: Boolean): Unit
  66. final def synchronized[T0](arg0: ⇒ T0): T0
    Definition Classes
    AnyRef
  67. def tanh_backward[S](gradOutput: STen, output: STen)(implicit arg0: Sc[S]): STen
  68. def tensorsFromFile[S](path: String, offset: Long, length: Long, pin: Boolean, tensors: List[(Byte, Long, Long)])(implicit arg0: Sc[S]): Vector[STen]

    Create tensors directly from file.

    Create tensors directly from file. Memory maps a file into host memory. Data is not passed through the JVM. Returned tensor is always on the CPU device.

    path

    file path

    offset

    byte offset into the file. Must be page aligned (usually multiple of 4096)

    length

    byte length of the data (all tensors in total)

    pin

    if true the mapped segment will be page locked with mlock(2)

    tensors

    list of tensors with (scalarType, byte offset, byte length), byte offset must be aligned to 8

    returns

    tensor on CPU

  69. def toString(): String
    Definition Classes
    AnyRef → Any
  70. def to_dense_backward[S](gradOutput: STen, input: STen)(implicit arg0: Sc[S]): STen
  71. def triangularSolve[S](b: STen, A: STen, upper: Boolean, transpose: Boolean, uniTriangular: Boolean)(implicit arg0: Sc[S]): STen
  72. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  73. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  74. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... ) @native()
  75. def where[S](condition: Tensor, self: STen, other: STen)(implicit arg0: Sc[S]): STen
  76. def where[S](condition: STen, self: STen, other: STen)(implicit arg0: Sc[S]): STen
  77. def zeros[S](size: Seq[Long], tensorOptions: STenOptions = STen.dOptions)(implicit arg0: Sc[S]): STen
  78. def zerosLike[S](tensor: STen)(implicit arg0: Sc[S]): STen
  79. def zerosLike[S](tensor: Tensor)(implicit arg0: Sc[S]): STen

Inherited from Serializable

Inherited from Serializable

Inherited from AnyRef

Inherited from Any

Ungrouped