All Downloads are FREE. Search and download functionalities are using the official Maven repository.

scalismo.statisticalmodel.experimental.StatisticalVolumeIntensityModel.scala Maven / Gradle / Ivy

There is a newer version: 1.0-RC1
Show newest version
package scalismo.statisticalmodel.experimental

import breeze.linalg.DenseVector
import scalismo.common._
import scalismo.geometry._
import scalismo.mesh._
import scalismo.statisticalmodel.{DiscreteLowRankGaussianProcess, PointDistributionModel}
import scalismo.utils.Random
import scalismo.common.DiscreteField.ScalarVolumeMeshField

import scala.reflect.ClassTag

trait StatisticalVolumeIntensityModel[S] {

  def referenceMeshField: ScalarVolumeMeshField[S]

  def shape: PointDistributionModel[_3D, TetrahedralMesh]

  def intensity: DiscreteLowRankGaussianProcess[_3D, UnstructuredPointsDomain, S]

  def mean: ScalarVolumeMeshField[S]

  def instance(coefficients: SVIMCoefficients): ScalarVolumeMeshField[S]

  def sample()(implicit rnd: Random): ScalarVolumeMeshField[S]

  def zeroCoefficients: SVIMCoefficients
}

object StatisticalVolumeIntensityModel {

  def apply[S: Scalar: ClassTag](
    referenceMeshField: ScalarVolumeMeshField[S],
    shape: PointDistributionModel[_3D, TetrahedralMesh],
    intensity: DiscreteLowRankGaussianProcess[_3D, UnstructuredPointsDomain, S]
  ): SVIM[S] = {
    SVIM(referenceMeshField, shape, intensity)
  }

}

case class SVIM[S: Scalar: ClassTag](
  referenceMeshField: ScalarVolumeMeshField[S],
  shape: PointDistributionModel[_3D, TetrahedralMesh],
  intensity: DiscreteLowRankGaussianProcess[_3D, UnstructuredPointsDomain, S]
) extends StatisticalVolumeIntensityModel[S] {

  override def mean: ScalarVolumeMeshField[S] = {
    ScalarVolumeMeshField(shape.mean, warpReferenceIntensity(intensity.mean.data))
  }

  override def instance(coefficients: SVIMCoefficients): ScalarVolumeMeshField[S] = {
    ScalarVolumeMeshField(shape.instance(coefficients.shape),
                          warpReferenceIntensity(intensity.instance(coefficients.intensity).data))
  }

  override def sample()(implicit rnd: Random): ScalarVolumeMeshField[S] = {
    ScalarVolumeMeshField(shape.sample(), warpReferenceIntensity(intensity.sample().data))
  }

  override def zeroCoefficients: SVIMCoefficients = SVIMCoefficients(
    DenseVector.zeros[Double](shape.rank),
    DenseVector.zeros[Double](intensity.rank)
  )

  def truncate(shapeComps: Int, colorComps: Int): SVIM[S] = {
    require(shapeComps >= 0 && shapeComps <= shape.rank, "illegal number of reduced shape components")
    require(colorComps >= 0 && colorComps <= intensity.rank, "illegal number of reduced color components")

    SVIM(
      referenceMeshField,
      shape.truncate(shapeComps),
      intensity.truncate(colorComps)
    )
  }

  private def warpReferenceIntensity(scalarData: IndexedSeq[S]): ScalarArray[S] = {
    ScalarArray[S](
      referenceMeshField.data
        .zip(ScalarArray[S](scalarData.toArray))
        .map { case (r, s) => Scalar[S].plus(r, s) }
        .toArray
    )
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy