commonMain.jetbrains.datalore.plot.base.pos.JitterPos.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of lets-plot-common Show documentation
Show all versions of lets-plot-common Show documentation
Lets-Plot JVM package without rendering part
/*
* Copyright (c) 2019. JetBrains s.r.o.
* Use of this source code is governed by the MIT license that can be found in the LICENSE file.
*/
package jetbrains.datalore.plot.base.pos
import jetbrains.datalore.base.geometry.DoubleVector
import jetbrains.datalore.plot.base.Aes
import jetbrains.datalore.plot.base.DataPointAesthetics
import jetbrains.datalore.plot.base.GeomContext
import jetbrains.datalore.plot.base.PositionAdjustment
import kotlin.random.Random
internal class JitterPos(width: Double?, height: Double?) : PositionAdjustment {
//uniform distribution
private val myWidth: Double
private val myHeight: Double
init {
myWidth = width ?: DEF_JITTER_WIDTH
myHeight = height ?: DEF_JITTER_HEIGHT
}
override fun translate(v: DoubleVector, p: DataPointAesthetics, ctx: GeomContext): DoubleVector {
val x = (2 * Random.nextDouble() - 1) * myWidth * ctx.getResolution(Aes.X)
val y = (2 * Random.nextDouble() - 1) * myHeight * ctx.getResolution(Aes.Y)
return v.add(DoubleVector(x, y))
}
override fun handlesGroups(): Boolean {
return PositionAdjustments.Meta.JITTER.handlesGroups()
}
companion object {
val DEF_JITTER_WIDTH = 0.4
val DEF_JITTER_HEIGHT = 0.4
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy