commonMain.jetbrains.datalore.base.gcommon.collect.ClosedRange.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.
*
* This file has been modified by JetBrains : Java code has been converted to Kotlin code.
*
* THE FOLLOWING IS THE COPYRIGHT OF THE ORIGINAL DOCUMENT:
*
* Copyright (C) 2007 The Guava Authors
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
* in compliance with the License. You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License
* is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
* or implied. See the License for the specific language governing permissions and limitations under
* the License.
*/
package jetbrains.datalore.base.gcommon.collect
import jetbrains.datalore.base.gcommon.collect.Comparables.gt
import jetbrains.datalore.base.gcommon.collect.Comparables.gte
import jetbrains.datalore.base.gcommon.collect.Comparables.ls
import jetbrains.datalore.base.gcommon.collect.Comparables.lse
import jetbrains.datalore.base.gcommon.collect.Comparables.max
import jetbrains.datalore.base.gcommon.collect.Comparables.min
open class ClosedRange>(
lower: T,
upper: T
) {
val lowerEnd: T
val upperEnd: T
init {
(lower as? Double)?.run {
check(isFinite()) {
"ends must be finite: lower=$lower upper=$upper"
}
}
(upper as? Double)?.run {
check(isFinite()) {
"ends must be finite: lower=$lower upper=$upper"
}
}
lowerEnd = min(lower, upper)
upperEnd = max(lower, upper)
}
operator fun contains(v: T): Boolean {
return lse(lowerEnd, v) && lse(v, upperEnd)
}
fun span(other: ClosedRange): ClosedRange {
if (encloses(other)) return this
return if (other.encloses(this)) other else ClosedRange(
min(lowerEnd, other.lowerEnd),
max(upperEnd, other.upperEnd)
)
}
fun encloses(other: ClosedRange): Boolean {
return lse(lowerEnd, other.lowerEnd) && gte(upperEnd, other.upperEnd)
}
fun isConnected(other: ClosedRange): Boolean {
return !(gt(lowerEnd, other.upperEnd) || ls(upperEnd, other.lowerEnd))
}
fun intersection(other: ClosedRange): ClosedRange {
if (!isConnected(other)) throw IllegalArgumentException("Ranges are not connected: this=$this other=$other")
if (encloses(other)) return other
return if (other.encloses(this)) this else ClosedRange(
max(lowerEnd, other.lowerEnd),
min(upperEnd, other.upperEnd)
)
}
override fun toString(): String {
return "ClosedRange[$lowerEnd, $upperEnd]"
}
override fun equals(other: Any?): Boolean {
if (this === other) return true
if (other == null || this::class != other::class) return false
other as ClosedRange<*>
if (lowerEnd != other.lowerEnd) return false
if (upperEnd != other.upperEnd) return false
return true
}
override fun hashCode(): Int {
return lowerEnd.hashCode() + 31 * upperEnd.hashCode()
}
companion object {
fun > singleton(v: T): ClosedRange {
return ClosedRange(v, v)
}
fun > encloseAll(values: Iterable): ClosedRange {
var iterated = false
var min: T? = null
var max: T? = null
for (v: T? in values) {
if (!iterated) {
iterated = true
min = v
max = v
} else {
min = min(min!!, v!!)
max = max(max!!, v)
}
}
if (!iterated) {
throw NoSuchElementException()
}
return ClosedRange(min!!, max!!)
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy